/* ============================================
   SundayMarathon.com - Dark Theme
   Fonts: Bebas Neue, DM Sans, Space Mono
   ============================================ */

/* ---------- CSS Custom Properties ---------- */
:root {
  --orange: #FF4D00;
  --orange-hover: #E64500;
  --orange-glow: rgba(255, 77, 0, 0.3);
  --dark: #0A0A0A;
  --dark-card: #141414;
  --dark-surface: #1A1A1A;
  --dark-border: #2A2A2A;
  --dark-hover: #1E1E1E;
  --white: #FAFAFA;
  --gray: #888;
  --gray-light: #AAA;
  --gray-dark: #666;
  --green: #00E676;
  --yellow: #FFD600;
  --blue: #448AFF;
  --red: #FF5252;
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 100px;
  --font-heading: 'Bebas Neue', 'Impact', sans-serif;
  --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'Space Mono', 'Courier New', monospace;
  --transition: 0.25s ease;
  --transition-slow: 0.4s ease;
  --shadow-card: 0 4px 24px rgba(0,0,0,0.3);
  --shadow-glow: 0 0 40px rgba(255, 77, 0, 0.15);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--white);background:var(--dark);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--orange);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--white)}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* Noise Overlay */
.noise-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;opacity:0.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}

/* Scroll animations */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.main-content{margin-top:72px}

/* Section label (monospace uppercase) */
.section-label{font-family:var(--font-mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--orange);margin-bottom:16px}

/* ==============================
   HEADER
   ============================== */
.site-header{position:fixed;top:0;left:0;right:0;background:rgba(10,10,10,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--dark-border);z-index:1000;height:72px}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:32px}
.logo{display:flex;align-items:center;gap:12px;font-family:var(--font-heading);font-size:24px;font-weight:400;color:var(--white);text-decoration:none;white-space:nowrap;flex-shrink:0;letter-spacing:2px;text-transform:uppercase}
.logo:hover{color:var(--white)}
.logo-icon{width:40px;height:40px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;flex-shrink:0}
.logo-text{color:var(--gray);font-weight:600;font-family:var(--font-body)}
.logo-text strong{color:var(--white);font-weight:800}

.nav-profile{width:36px;height:36px;border-radius:50%;background:var(--dark-surface);border:1px solid var(--dark-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);font-size:16px;margin-left:8px;flex-shrink:0}
.nav-profile:hover{border-color:var(--orange)}
.nav-cta{padding:10px 24px;background:var(--orange);color:var(--white);border-radius:var(--radius-full);font-size:13px;font-weight:600;transition:all var(--transition);white-space:nowrap;flex-shrink:0;text-decoration:none;font-family:var(--font-body);text-transform:none;letter-spacing:0}
.nav-cta:hover{background:var(--orange-hover);color:var(--white)}

.main-nav{display:flex;align-items:center;gap:2px}
.main-nav a{color:var(--gray);font-size:14px;font-weight:500;padding:8px 16px;border-radius:var(--radius-full);transition:all var(--transition);white-space:nowrap}
.main-nav a:hover,.main-nav a.active{color:var(--white);background:var(--dark-surface)}

.header-search{position:relative;flex-shrink:0}
.search-mini{position:relative;display:flex;align-items:center}
.search-mini-input{width:220px;padding:9px 16px 9px 40px;border:1px solid var(--dark-border);border-radius:var(--radius-full);font-size:14px;background:var(--dark-surface);color:var(--white);transition:all var(--transition);outline:none}
.search-mini-input::placeholder{color:var(--gray-dark)}
.search-mini-input:focus{border-color:var(--orange);background:var(--dark-card);width:280px;box-shadow:0 0 0 3px var(--orange-glow)}
.search-mini-btn{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray);display:flex;padding:0}

.search-results-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:320px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);box-shadow:var(--shadow-card);max-height:400px;overflow-y:auto;display:none;z-index:1001}
.search-results-dropdown.active{display:block}
.search-results-dropdown .search-result-item{display:block;padding:12px 16px;border-bottom:1px solid var(--dark-border);color:var(--white);transition:background var(--transition)}
.search-results-dropdown .search-result-item:last-child{border-bottom:none}
.search-results-dropdown .search-result-item:hover{background:var(--dark-surface)}
.search-results-dropdown .search-result-item .result-name{font-weight:600;font-size:14px}
.search-results-dropdown .search-result-item .result-meta{font-size:12px;color:var(--gray);margin-top:2px}
.search-results-dropdown .search-no-results{padding:16px;text-align:center;color:var(--gray);font-size:14px}

.mobile-menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;padding:6px;border-radius:var(--radius-sm)}
.mobile-menu-btn:hover{background:var(--dark-surface)}
.mobile-menu-btn span{display:block;width:100%;height:2px;background:var(--white);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.mobile-menu-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-btn.active span:nth-child(2){opacity:0}
.mobile-menu-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ==============================
   BREADCRUMBS
   ============================== */
.breadcrumbs{padding:16px 0;font-size:13px;color:var(--gray)}
.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:0;list-style:none;padding:0;margin:0}
.breadcrumb-item{display:flex;align-items:center}
.breadcrumb-item+.breadcrumb-item::before{content:'/';margin:0 8px;color:var(--dark-border)}
.breadcrumbs a{color:var(--gray);text-decoration:none}
.breadcrumbs a:hover{color:var(--orange)}
.breadcrumb-item.active{color:var(--white);font-weight:500}

/* ==============================
   HERO
   ============================== */
.hero{padding:160px 0 100px;background:var(--dark);color:var(--white);text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 50% 0%,rgba(255,77,0,0.12) 0%,transparent 60%)}
.hero .container{position:relative;z-index:1}

.hero-badge{display:inline-block;padding:8px 24px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:3px;margin-bottom:32px;text-transform:uppercase;color:var(--orange)}

.hero-title{font-family:var(--font-heading);font-size:90px;font-weight:400;line-height:0.95;margin-bottom:24px;letter-spacing:2px;text-transform:uppercase}
.hero-highlight{color:var(--orange)}

.hero-subtitle{font-size:18px;color:var(--gray);margin-bottom:48px;font-weight:400;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.6}

.hero-search{max-width:640px;margin:0 auto 40px}
.hero-search-inner{display:flex;align-items:center;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-full);overflow:hidden;position:relative;transition:border-color var(--transition)}
.hero-search-inner:focus-within{border-color:var(--orange)}
.hero-search-icon{position:absolute;left:20px;color:var(--gray);pointer-events:none;z-index:1}
.hero-search input{flex:1;padding:18px 20px 18px 52px;border:none;font-size:16px;outline:none;color:var(--white);background:transparent}
.hero-search input::placeholder{color:var(--gray-dark)}
.hero-search button{padding:14px 32px;margin:4px;background:var(--orange);color:var(--white);font-size:15px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition);white-space:nowrap}
.hero-search button:hover{background:var(--orange-hover)}

.hero-quick-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.hero-quick-links a{color:var(--gray);font-size:14px;font-weight:500;padding:10px 22px;border:1px solid var(--dark-border);border-radius:var(--radius-full);transition:all var(--transition);display:inline-flex;align-items:center;gap:8px}
.hero-quick-links a:hover{color:var(--white);background:var(--dark-surface);border-color:var(--gray-dark)}
.hero-quick-links a svg{opacity:0.6}

.hero-wave{display:none}

/* ==============================
   STATS BAR
   ============================== */
.stats-bar{padding:40px 0;border-bottom:1px solid var(--dark-border);background:var(--dark-card)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-item{padding:12px}
.stat-number{font-family:var(--font-heading);font-size:48px;font-weight:400;color:var(--white);line-height:1;letter-spacing:1px}
.stat-label{font-family:var(--font-mono);font-size:11px;color:var(--gray);font-weight:400;margin-top:8px;text-transform:uppercase;letter-spacing:2px}

/* ==============================
   SECTIONS
   ============================== */
.section{padding:80px 0}
.section-alt{background:var(--dark-card)}

.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:12px}
.section-header-center{text-align:center;margin-bottom:56px}
.section-title{font-family:var(--font-heading);font-size:48px;font-weight:400;color:var(--white);line-height:1;letter-spacing:1px;text-transform:uppercase}
.section-subtitle{font-size:16px;color:var(--gray);margin-top:16px;max-width:500px;margin-left:auto;margin-right:auto}

.view-all{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--orange);display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:1px;transition:gap var(--transition)}
.view-all:hover{gap:10px;color:var(--orange)}

/* ==============================
   FEATURES GRID
   ============================== */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:32px 24px;transition:all var(--transition-slow)}
.feature-card:hover{border-color:var(--orange);box-shadow:var(--shadow-glow);transform:translateY(-4px)}
.feature-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.feature-icon-blue{background:rgba(68,138,255,0.15);color:var(--blue)}
.feature-icon-orange{background:rgba(255,77,0,0.15);color:var(--orange)}
.feature-icon-green{background:rgba(0,230,118,0.15);color:var(--green)}
.feature-icon-purple{background:rgba(179,136,255,0.15);color:#B388FF}
.feature-card h3{font-size:18px;font-weight:700;margin-bottom:10px;color:var(--white)}
.feature-card p{font-size:14px;color:var(--gray);line-height:1.7}

/* ==============================
   POPULAR COUNTRIES
   ============================== */
.popular-countries-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.popular-country-card{display:flex;align-items:center;gap:12px;padding:16px 18px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);transition:all var(--transition);color:var(--white)}
.popular-country-card:hover{border-color:var(--orange);box-shadow:0 0 20px rgba(255,77,0,0.1);color:var(--white);transform:translateY(-2px)}
.popular-country-flag{font-size:24px;line-height:1;flex-shrink:0}
.popular-country-name{flex:1;font-weight:600;font-size:15px}
.popular-country-arrow{color:var(--gray-dark);transition:all var(--transition);flex-shrink:0}
.popular-country-card:hover .popular-country-arrow{color:var(--orange);transform:translateX(3px)}

/* ==============================
   CONTINENT BROWSING
   ============================== */
.continent-section{margin-bottom:36px}
.continent-section:last-child{margin-bottom:0}
.continent-heading{font-family:var(--font-heading);font-size:28px;font-weight:400;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--orange);display:inline-block;letter-spacing:1px;text-transform:uppercase}
.continent-count{font-family:var(--font-body);font-weight:400;color:var(--gray);font-size:16px}

.country-pills{display:flex;flex-wrap:wrap;gap:8px}
.country-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--gray);transition:all var(--transition)}
.country-pill:hover{background:var(--dark-surface);border-color:var(--orange);color:var(--orange)}
.country-pill-flag{font-size:15px;line-height:1}

/* Page titles */
.page-title{font-family:var(--font-heading);font-size:56px;font-weight:400;color:var(--white);line-height:1;margin-bottom:12px;letter-spacing:1px;text-transform:uppercase}
.page-subtitle{font-size:16px;color:var(--gray);margin-bottom:32px}

/* Continent Grid (countries listing) */
.continent-grid{display:grid;gap:48px}
.continent-name,.continent-block h2{font-family:var(--font-heading);font-size:28px;font-weight:400;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--orange);display:inline-block;letter-spacing:1px;text-transform:uppercase}
.country-cards{display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}
.country-card{display:flex;align-items:center;gap:10px;padding:14px 18px;border:1px solid var(--dark-border);border-radius:var(--radius);transition:all var(--transition);color:var(--gray);background:var(--dark-card)}
.country-card:hover{background:var(--dark-surface);border-color:var(--orange);color:var(--orange);transform:translateX(4px)}
.country-card .country-flag{font-size:20px}
.country-card .country-name{flex:1;font-weight:500;font-size:15px}
.country-card .country-count{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--gray-dark);background:var(--dark-surface);padding:4px 12px;border-radius:var(--radius-full);letter-spacing:0.5px}

/* ==============================
   MARATHON GRID & CARDS
   ============================== */
.marathon-grid{display:grid;gap:24px}
.marathon-grid-3{grid-template-columns:repeat(3,1fr)}
.marathon-grid-4{grid-template-columns:repeat(4,1fr)}

.marathon-card{background:var(--dark-card);border-radius:var(--radius);border:1px solid var(--dark-border);overflow:hidden;transition:all var(--transition-slow);display:flex;flex-direction:column}
.marathon-card:hover{box-shadow:var(--shadow-card);transform:translateY(-4px);border-color:rgba(255,77,0,0.3)}
.marathon-card a,.marathon-card-link{color:inherit;text-decoration:none}

.marathon-card-image{position:relative;padding-top:56.25%;overflow:hidden;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%)}
.marathon-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}
.marathon-card:hover .marathon-card-image img{transform:scale(1.05)}
.marathon-card-placeholder{padding-top:40%;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%)}
.marathon-card-placeholder .placeholder-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:40px;opacity:0.4}

.marathon-card-body{padding:20px;display:flex;gap:14px;flex:1}
.marathon-card-date{flex-shrink:0;text-align:center;min-width:48px}
.marathon-card-date .date-month{font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;color:var(--orange);letter-spacing:1px}
.marathon-card-date .date-day{font-family:var(--font-heading);font-size:32px;font-weight:400;line-height:1;color:var(--white)}
.marathon-card-info{flex:1;min-width:0}
.marathon-card-title{font-size:16px;font-weight:600;line-height:1.4;margin-bottom:4px;color:var(--white);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.marathon-card-location{font-size:14px;color:var(--gray);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.marathon-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.marathon-card-distances{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--gray);letter-spacing:0.5px;text-transform:uppercase}
.badge-sponsored{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:700;padding:3px 10px;background:var(--orange);color:var(--white);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:1px}

/* ==============================
   MARATHON DETAIL
   ============================== */
.marathon-layout{display:flex;gap:40px;padding:40px 0}
.marathon-main{flex:1;min-width:0}
.marathon-sidebar{width:300px;flex-shrink:0}

.marathon-header{margin-bottom:32px}
.marathon-title{font-family:var(--font-heading);font-size:56px;font-weight:400;line-height:1;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.marathon-tagline{font-size:18px;color:var(--gray);margin-top:8px}

.marathon-section{margin:40px 0}
.marathon-section h2{font-family:var(--font-heading);font-size:28px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--dark-border)}
.marathon-description{color:var(--gray-light);line-height:1.8}

.key-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:24px 0}
.fact,.key-fact{border-left:3px solid var(--orange);padding-left:16px}
.fact-label,.key-fact-label{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin-bottom:4px}
.fact-value,.key-fact-value{font-size:18px;font-weight:700;color:var(--white)}
.fact-sub{font-size:13px;color:var(--gray);margin-top:2px;display:block}

.details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0}
.detail-item .detail-label,.details-item .details-label{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin-bottom:4px}
.detail-item .detail-value,.details-item .details-value{font-size:15px;font-weight:500;color:var(--white)}
.registration-cta{text-align:center;padding:32px 0}
.registration-cta .btn{font-size:18px;padding:16px 48px}
.btn-sub{display:block;font-size:12px;opacity:0.7;margin-top:2px}

.sidebar-widget{background:var(--dark-card);border-radius:var(--radius);padding:24px;border:1px solid var(--dark-border);margin-bottom:24px}
.widget-title{font-family:var(--font-heading);font-size:22px;font-weight:400;letter-spacing:1px;text-transform:uppercase;padding-bottom:12px;border-bottom:1px solid var(--dark-border);margin-bottom:16px}

.related-list{list-style:none}
.related-item{padding:12px 0;border-bottom:1px solid var(--dark-border)}
.related-item:last-child{border-bottom:none}
.related-item a{display:block;color:var(--white)}
.related-item a:hover{color:var(--orange)}
.related-item .related-name{font-size:14px;font-weight:600;margin-bottom:2px}
.related-item .related-date{font-size:12px;color:var(--gray)}

/* FAQ */
.faq-section{margin:40px 0}
.faq-item{border:1px solid var(--dark-border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;background:var(--dark-card)}
.faq-item summary{font-size:16px;font-weight:600;padding:16px 48px 16px 20px;cursor:pointer;position:relative;list-style:none;transition:background var(--transition);color:var(--white)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary::after{content:'+';position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:20px;font-weight:400;color:var(--gray)}
.faq-item[open] summary::after{content:'\2212'}
.faq-item summary:hover{background:var(--dark-surface)}
.faq-answer{padding:0 20px 20px;border-top:1px solid var(--dark-border);color:var(--gray);line-height:1.7}
.faq-answer p{margin-top:12px}

/* ==============================
   CALENDAR
   ============================== */
.calendar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.calendar-month-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:28px;text-align:center;transition:all var(--transition);color:var(--white)}
.calendar-month-card:hover{border-color:var(--orange);box-shadow:var(--shadow-glow);transform:translateY(-3px);color:var(--white)}
.calendar-month-card.past{opacity:0.4}
.calendar-month-card .month-name,.calendar-month-card .cal-month-name{font-family:var(--font-heading);font-size:24px;font-weight:400;color:var(--white);letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:4px}
.calendar-month-card .month-count,.calendar-month-card .cal-month-count{font-family:var(--font-mono);font-size:12px;color:var(--gray);display:block;letter-spacing:0.5px}

.calendar-nav,.year-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px}
.calendar-year,.year-current{font-family:var(--font-heading);font-size:32px;font-weight:400;color:var(--white);letter-spacing:1px}
.year-nav a{padding:8px 18px;border:1px solid var(--dark-border);border-radius:var(--radius-full);font-weight:600;color:var(--gray);transition:all var(--transition)}
.year-nav a:hover{border-color:var(--orange);color:var(--orange)}

/* ==============================
   SEARCH
   ============================== */
.search-form{margin-bottom:32px;background:var(--dark-card);padding:28px;border-radius:var(--radius);border:1px solid var(--dark-border)}
.search-fields{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}
.search-field{flex:1;min-width:180px}
.search-field label{display:block;font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;color:var(--gray)}
.search-submit{flex:0 0 auto;min-width:auto}
.search-submit .btn{padding:12px 28px}
.search-summary{font-family:var(--font-mono);font-size:13px;color:var(--gray);margin-bottom:24px;letter-spacing:0.5px}
.form-label{display:block;font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;color:var(--gray)}
.form-input{width:100%;padding:12px 16px;border:1px solid var(--dark-border);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:all var(--transition);background:var(--dark-surface);color:var(--white)}
.form-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-glow)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}

/* ==============================
   BLOG
   ============================== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:var(--dark-card);border-radius:var(--radius);border:1px solid var(--dark-border);overflow:hidden;transition:all var(--transition-slow)}
.blog-card:hover{box-shadow:var(--shadow-card);transform:translateY(-3px)}
.blog-card-image{position:relative;padding-top:56.25%;overflow:hidden;background:var(--dark-surface)}
.blog-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.blog-card-body{padding:20px}
.blog-card-category{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--orange);margin-bottom:8px}
.blog-card-title{font-size:18px;font-weight:700;line-height:1.4;margin-bottom:8px}
.blog-card-title a{color:var(--white)}
.blog-card-title a:hover{color:var(--orange)}
.blog-card-excerpt{font-size:14px;color:var(--gray);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-meta{font-size:12px;color:var(--gray-dark);margin-top:12px}

/* ==============================
   CONTENT PAGES
   ============================== */
.content-page{max-width:800px;margin:0 auto;padding:48px 24px}
.content-page .page-title{font-size:56px;margin-bottom:24px}
.content-body h2{font-family:var(--font-heading);font-size:32px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-top:40px;margin-bottom:16px}
.content-body h3{font-size:20px;font-weight:600;margin-top:32px;margin-bottom:12px}
.content-body p{margin-bottom:16px;line-height:1.8;color:var(--gray-light)}
.content-body ul,.content-body ol{margin-bottom:16px;padding-left:24px}
.content-body ul{list-style:disc}
.content-body ol{list-style:decimal}
.content-body li{margin-bottom:8px;line-height:1.7;color:var(--gray-light)}
.content-body blockquote{border-left:4px solid var(--orange);padding:16px 24px;margin:24px 0;background:var(--dark-card);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--gray)}
.content-body a{color:var(--orange);text-decoration:underline;text-underline-offset:2px}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:32px 0}
.contact-form .form-group{margin-bottom:20px}
.contact-info-card{background:var(--dark-card);border-radius:var(--radius);padding:32px;border:1px solid var(--dark-border)}
.contact-info-card h3{font-size:20px;font-weight:700;margin-bottom:16px}
.contact-info-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:14px;color:var(--gray)}
.contact-info-item .info-icon{font-size:18px;flex-shrink:0}

/* ==============================
   NEWSLETTER / CTA
   ============================== */
.section-cta{background:var(--dark-card);border-top:1px solid var(--dark-border);border-bottom:1px solid var(--dark-border);color:var(--white);text-align:center;padding:80px 0;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 50% 50%,rgba(255,77,0,0.08) 0%,transparent 60%)}
.cta-content{position:relative;z-index:1}
.section-cta .section-title{color:var(--white);margin-bottom:16px}
.section-cta p{color:var(--gray);margin-bottom:32px;font-size:17px}
.newsletter-form{display:flex;max-width:500px;margin:0 auto;border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--dark-border);background:var(--dark-surface)}
.newsletter-form input{flex:1;padding:16px 20px;border:none;font-size:15px;outline:none;background:transparent;color:var(--white)}
.newsletter-form input::placeholder{color:var(--gray-dark)}
.newsletter-form button{padding:12px 28px;margin:4px;background:var(--orange);color:var(--white);font-size:15px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition);white-space:nowrap}
.newsletter-form button:hover{background:var(--orange-hover)}
.newsletter-note{font-size:13px;color:var(--gray-dark);margin-top:16px}

/* ==============================
   PAGINATION
   ============================== */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:40px 0}
.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 10px;border:1px solid var(--dark-border);border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--white);background:var(--dark-card);transition:all var(--transition);text-decoration:none}
.pagination-btn:hover{background:var(--dark-surface);border-color:var(--orange);color:var(--orange)}
.pagination-btn.pagination-current{background:var(--orange);color:var(--white);border-color:var(--orange)}
.pagination-btn.disabled{opacity:0.3;pointer-events:none}
.pagination-ellipsis{min-width:42px;text-align:center;color:var(--gray)}

/* ==============================
   BUTTONS
   ============================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--radius-full);font-size:14px;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all var(--transition);text-decoration:none;line-height:1.4}
.btn-primary{background:var(--orange);color:var(--white)}
.btn-primary:hover{background:var(--orange-hover);color:var(--white);box-shadow:var(--shadow-glow)}
.btn-secondary{background:var(--dark-surface);color:var(--white);border-color:var(--dark-border)}
.btn-secondary:hover{background:var(--dark-hover);border-color:var(--orange);color:var(--orange)}
.btn-outline{background:transparent;border-color:var(--dark-border);color:var(--gray)}
.btn-outline:hover{background:var(--dark-surface);border-color:var(--orange);color:var(--orange)}
.btn-lg{padding:16px 40px;font-size:16px}
.btn-sm{padding:7px 16px;font-size:13px}
.btn-block{display:flex;width:100%}

/* ==============================
   ALERTS
   ============================== */
.alert{padding:14px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;margin-bottom:20px;border:1px solid}
.alert-success{background:rgba(0,230,118,0.1);border-color:rgba(0,230,118,0.3);color:var(--green)}
.alert-error{background:rgba(255,82,82,0.1);border-color:rgba(255,82,82,0.3);color:var(--red)}

/* AD SLOTS */
.ad-slot{text-align:center;overflow:hidden;margin:24px auto}
.ad-slot-leaderboard{min-height:90px;max-width:728px}
.ad-slot-sidebar{min-height:250px;max-width:300px}
.ad-slot-inline{min-height:100px}

/* ==============================
   FOOTER
   ============================== */
.site-footer{background:var(--dark-card);border-top:1px solid var(--dark-border);color:var(--gray);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px}
.footer-title{color:var(--white);font-family:var(--font-heading);font-size:28px;font-weight:400;margin-bottom:12px;letter-spacing:1px;text-transform:uppercase}
.footer-heading,.footer-col h4{font-family:var(--font-mono);color:var(--white);font-size:11px;font-weight:700;margin-bottom:20px;text-transform:uppercase;letter-spacing:2px}
.footer-desc,.footer-about{font-size:14px;line-height:1.7;margin-bottom:16px;color:var(--gray-dark)}
.footer-links{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{color:var(--gray-dark);font-size:14px;transition:color var(--transition)}
.footer-links a:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid var(--dark-border);padding:20px 0;text-align:center;font-size:13px;color:var(--gray-dark)}
.footer-bottom a{color:var(--gray)}
.footer-bottom a:hover{color:var(--orange)}

/* TAG CLOUD */
.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}
.tag{display:inline-block;padding:8px 18px;border:1px solid var(--dark-border);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--gray);transition:all var(--transition)}
.tag:hover{background:var(--orange);color:var(--white);border-color:var(--orange)}

/* ==============================
   UTILITIES
   ============================== */
.empty-state{text-align:center;padding:60px 20px;color:var(--gray)}
.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:0.3}
.empty-state .empty-text{font-size:16px;margin-bottom:8px}

.badge{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:700;padding:4px 12px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:1px}
.badge-green{background:rgba(0,230,118,0.15);color:var(--green)}
.badge-blue{background:rgba(68,138,255,0.15);color:var(--blue)}
.badge-orange{background:rgba(255,77,0,0.15);color:var(--orange)}

.flag{font-size:18px;line-height:1}
.flag-large{font-size:28px;line-height:1}

.text-center{text-align:center}
.text-muted{color:var(--gray)}

.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}

.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ==============================
   NEW MARATHON CARD (Reference Design)
   ============================== */
.card{background:var(--dark-card);border-radius:var(--radius);border:1px solid var(--dark-border);overflow:hidden;transition:all var(--transition-slow);display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-card);transform:translateY(-4px);border-color:rgba(255,77,0,0.3)}
.card-img{position:relative;height:180px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.card-img-fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;color:rgba(255,255,255,0.7)}
.card-img-fallback .card-emoji{font-size:48px;line-height:1}
.card-img-fallback .card-city{font-size:13px;opacity:0.8}
.card-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:var(--radius-full);font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;z-index:2}
.card-badge-open{background:rgba(0,230,118,0.2);color:var(--green)}
.card-badge-closing{background:rgba(255,214,0,0.2);color:var(--yellow)}
.card-badge-sold-out{background:rgba(255,82,82,0.2);color:var(--red)}
.card-badge-featured{background:rgba(255,77,0,0.2);color:var(--orange)}
.card-date{position:absolute;top:12px;right:12px;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);padding:6px 12px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--white);z-index:2}
.card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.card-location{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--orange);margin-bottom:6px}
.card-name{font-family:var(--font-heading);font-size:24px;font-weight:400;letter-spacing:1px;text-transform:uppercase;line-height:1.1;margin-bottom:10px;color:var(--white)}
.card-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--gray);flex-wrap:wrap}
.card-meta span{display:inline-flex;align-items:center;gap:4px}
.card-meta svg{width:14px;height:14px;opacity:0.6}
.card-footer{padding:14px 20px;border-top:1px solid var(--dark-border);display:flex;align-items:center;justify-content:space-between}
.card-price{font-weight:700;color:var(--white);font-size:15px}
.card-price span{font-size:12px;color:var(--gray);font-weight:400}
.card-link{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:1px;transition:gap var(--transition);display:inline-flex;align-items:center;gap:4px}
.card-link:hover{gap:8px;color:var(--orange)}

/* Card grid for new cards */
.card-grid{display:grid;gap:24px}
.card-grid-3{grid-template-columns:repeat(3,1fr)}
.card-grid-4{grid-template-columns:repeat(4,1fr)}

/* ==============================
   TABS
   ============================== */
.tabs{display:flex;gap:4px;margin-bottom:32px;border-bottom:1px solid var(--dark-border);padding-bottom:0}
.tab{padding:12px 24px;font-size:14px;font-weight:600;color:var(--gray);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);background:none;border-top:none;border-left:none;border-right:none;margin-bottom:-1px}
.tab:hover{color:var(--white)}
.tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ==============================
   COMMUNITY PAGE
   ============================== */
.community-layout{display:grid;grid-template-columns:240px 1fr 240px;gap:0;min-height:calc(100vh - 200px);background:var(--dark-card);border-radius:var(--radius);border:1px solid var(--dark-border);overflow:hidden}
.community-sidebar{background:var(--dark-surface);border-right:1px solid var(--dark-border);padding:20px 0}
.community-sidebar h3{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gray);padding:0 16px;margin-bottom:12px}
.channel-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background var(--transition);color:var(--gray);font-size:14px}
.channel-item:hover,.channel-item.active{background:rgba(255,77,0,0.1);color:var(--white)}
.channel-item.active{border-left:3px solid var(--orange);padding-left:13px}
.channel-item .channel-icon{font-size:18px;flex-shrink:0}
.channel-item .channel-unread{margin-left:auto;background:var(--orange);color:var(--white);font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);min-width:20px;text-align:center}

.community-main{display:flex;flex-direction:column}
.chat-header{padding:16px 20px;border-bottom:1px solid var(--dark-border);display:flex;align-items:center;justify-content:space-between}
.chat-header h2{font-family:var(--font-heading);font-size:24px;font-weight:400;letter-spacing:1px;text-transform:uppercase}
.chat-header .chat-online{font-size:12px;color:var(--green);display:flex;align-items:center;gap:6px}
.chat-header .chat-online::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--green)}

.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;max-height:500px}
.chat-msg{display:flex;gap:12px;align-items:flex-start}
.chat-msg-avatar{width:36px;height:36px;border-radius:50%;background:var(--dark-surface);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;border:1px solid var(--dark-border)}
.chat-msg-content{flex:1;min-width:0}
.chat-msg-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.chat-msg-name{font-weight:700;font-size:14px;color:var(--white)}
.chat-msg-time{font-size:11px;color:var(--gray)}
.chat-msg-text{font-size:14px;color:var(--gray-light);line-height:1.6}

.chat-input{padding:16px 20px;border-top:1px solid var(--dark-border);display:flex;gap:12px}
.chat-input input{flex:1;padding:12px 16px;background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:var(--radius-full);color:var(--white);font-size:14px;outline:none;transition:border-color var(--transition)}
.chat-input input:focus{border-color:var(--orange)}
.chat-input button{padding:12px 24px;background:var(--orange);color:var(--white);border-radius:var(--radius-full);font-weight:600;font-size:14px;transition:background var(--transition)}
.chat-input button:hover{background:var(--orange-hover)}

.community-members{background:var(--dark-surface);border-left:1px solid var(--dark-border);padding:20px 0}
.community-members h3{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gray);padding:0 16px;margin-bottom:12px}
.member-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13px;color:var(--gray)}
.member-item .member-avatar{width:28px;height:28px;border-radius:50%;background:var(--dark-card);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.member-item .member-name{flex:1}
.member-item .member-status{width:8px;height:8px;border-radius:50%}
.member-item .member-status.online{background:var(--green)}
.member-item .member-status.offline{background:var(--gray-dark)}

/* Match Card */
.match-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:32px;text-align:center}
.match-card h3{font-family:var(--font-heading);font-size:28px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.match-card p{color:var(--gray);font-size:14px;margin-bottom:24px}
.match-card .match-avatars{display:flex;justify-content:center;gap:8px;margin-bottom:20px}
.match-card .match-avatar{width:56px;height:56px;border-radius:50%;background:var(--dark-surface);border:2px solid var(--dark-border);display:flex;align-items:center;justify-content:center;font-size:24px}
.match-card .match-avatar.match-you{border-color:var(--orange)}
.match-card .match-vs{display:flex;align-items:center;font-family:var(--font-heading);font-size:24px;color:var(--gray)}

/* ==============================
   PRICING PAGE
   ============================== */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px}
.pricing-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:32px;position:relative;transition:all var(--transition-slow);display:flex;flex-direction:column}
.pricing-card:hover{border-color:rgba(255,77,0,0.3);transform:translateY(-4px)}
.pricing-card.popular{border-color:var(--orange);box-shadow:0 0 40px rgba(255,77,0,0.15)}
.popular-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--orange);color:var(--white);font-family:var(--font-mono);font-size:10px;font-weight:700;padding:4px 16px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}
.pricing-card h3{font-family:var(--font-heading);font-size:32px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.pricing-card .pricing-price{font-family:var(--font-heading);font-size:56px;font-weight:400;color:var(--white);margin-bottom:4px;letter-spacing:1px}
.pricing-card .pricing-price span{font-size:18px;color:var(--gray);font-family:var(--font-body);font-weight:400}
.pricing-card .pricing-desc{font-size:14px;color:var(--gray);margin-bottom:24px}
.pricing-features{list-style:none;margin-bottom:32px;flex:1}
.pricing-features li{padding:8px 0;font-size:14px;color:var(--gray-light);display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--dark-border)}
.pricing-features li:last-child{border-bottom:none}
.pricing-features li .check{color:var(--green);font-weight:700;font-size:16px;flex-shrink:0}
.pricing-features li .cross{color:var(--gray-dark);font-size:16px;flex-shrink:0}
.pricing-btn{display:block;width:100%;padding:14px;text-align:center;border-radius:var(--radius-full);font-weight:600;font-size:15px;transition:all var(--transition);cursor:pointer;text-decoration:none}
.pricing-btn-primary{background:var(--orange);color:var(--white);border:none}
.pricing-btn-primary:hover{background:var(--orange-hover);color:var(--white)}
.pricing-btn-outline{background:transparent;color:var(--white);border:1px solid var(--dark-border)}
.pricing-btn-outline:hover{border-color:var(--orange);color:var(--orange)}

/* FAQ Accordion */
.faq-grid{max-width:800px;margin:0 auto}
.faq-accordion{border:1px solid var(--dark-border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;background:var(--dark-card)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-size:15px;font-weight:600;color:var(--white);transition:background var(--transition);background:none;border:none;width:100%;text-align:left}
.faq-question:hover{background:var(--dark-surface)}
.faq-question .faq-toggle{font-size:20px;color:var(--gray);transition:transform var(--transition);flex-shrink:0}
.faq-accordion.open .faq-question .faq-toggle{transform:rotate(45deg)}
.faq-answer-content{max-height:0;overflow:hidden;transition:max-height 0.3s ease}
.faq-accordion.open .faq-answer-content{max-height:200px}
.faq-answer-inner{padding:0 20px 16px;color:var(--gray);font-size:14px;line-height:1.7}

/* ==============================
   PROFILE PAGE
   ============================== */
.profile-header{display:flex;align-items:center;gap:24px;margin-bottom:40px;padding:32px;background:var(--dark-card);border-radius:var(--radius);border:1px solid var(--dark-border)}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:36px;flex-shrink:0;border:3px solid var(--dark-border)}
.profile-info h1{font-family:var(--font-heading);font-size:36px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.profile-info p{font-size:14px;color:var(--gray)}
.profile-info .profile-location{display:flex;align-items:center;gap:6px;margin-top:4px}

.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:40px}
.profile-stat{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px;text-align:center}
.profile-stat .stat-val{font-family:var(--font-heading);font-size:36px;font-weight:400;color:var(--white);line-height:1}
.profile-stat .stat-lbl{font-family:var(--font-mono);font-size:11px;color:var(--gray);margin-top:4px;text-transform:uppercase;letter-spacing:1px}

.race-history-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);margin-bottom:12px;transition:border-color var(--transition)}
.race-history-item:hover{border-color:rgba(255,77,0,0.3)}
.race-history-item .rh-emoji{font-size:28px;flex-shrink:0}
.race-history-item .rh-info{flex:1}
.race-history-item .rh-name{font-weight:700;font-size:15px;color:var(--white)}
.race-history-item .rh-detail{font-size:13px;color:var(--gray);margin-top:2px}
.race-history-item .rh-time{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--orange);flex-shrink:0}

.saved-race-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);margin-bottom:12px;transition:border-color var(--transition)}
.saved-race-item:hover{border-color:rgba(255,77,0,0.3)}
.saved-race-item .sr-emoji{font-size:28px;flex-shrink:0}
.saved-race-item .sr-info{flex:1}
.saved-race-item .sr-name{font-weight:700;font-size:15px;color:var(--white)}
.saved-race-item .sr-detail{font-size:13px;color:var(--gray);margin-top:2px}
.saved-race-item .sr-btn{padding:8px 18px;border:1px solid var(--dark-border);border-radius:var(--radius-full);font-size:12px;font-weight:600;color:var(--gray);transition:all var(--transition);background:none;cursor:pointer;flex-shrink:0}
.saved-race-item .sr-btn:hover{border-color:var(--orange);color:var(--orange)}

.settings-form .settings-group{margin-bottom:24px}
.settings-form label{display:block;font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;color:var(--gray)}
.settings-form input,.settings-form select{width:100%;padding:12px 16px;background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:var(--radius-sm);color:var(--white);font-size:14px;outline:none;transition:border-color var(--transition)}
.settings-form input:focus,.settings-form select:focus{border-color:var(--orange)}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ==============================
   ABOUT PAGE
   ============================== */
.about-hero{text-align:center;padding:80px 0 48px}
.about-hero h1{font-family:var(--font-heading);font-size:56px;font-weight:400;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}
.about-hero p{font-size:18px;color:var(--gray);max-width:600px;margin:0 auto}

.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px}
.about-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:32px;text-align:center;transition:all var(--transition-slow)}
.about-card:hover{border-color:var(--orange);transform:translateY(-4px)}
.about-card .about-icon{font-size:40px;margin-bottom:16px}
.about-card h3{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--white)}
.about-card p{font-size:14px;color:var(--gray);line-height:1.7}

.timeline{position:relative;max-width:600px;margin:0 auto;padding-left:32px}
.timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--dark-border)}
.timeline-item{position:relative;margin-bottom:32px;padding-left:24px}
.timeline-item::before{content:'';position:absolute;left:-28px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--orange);border:3px solid var(--dark)}
.timeline-item .timeline-year{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.timeline-item h4{font-size:16px;font-weight:700;color:var(--white);margin-bottom:4px}
.timeline-item p{font-size:14px;color:var(--gray);line-height:1.6}

/* ==============================
   DETAIL PAGE OVERLAY STYLE
   ============================== */
.detail-hero{position:relative;height:300px;overflow:hidden;display:flex;align-items:flex-end}
.detail-hero-bg{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}
.detail-hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:32px;background:linear-gradient(transparent,rgba(10,10,10,0.95))}
.detail-hero-overlay h1{font-family:var(--font-heading);font-size:48px;font-weight:400;letter-spacing:2px;text-transform:uppercase;line-height:1}
.detail-hero-overlay .detail-location{font-family:var(--font-mono);font-size:12px;color:var(--orange);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}

.detail-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--dark-border);margin-bottom:32px}
.detail-stat{background:var(--dark-card);padding:20px;text-align:center}
.detail-stat .ds-val{font-family:var(--font-heading);font-size:28px;color:var(--white);letter-spacing:1px}
.detail-stat .ds-lbl{font-family:var(--font-mono);font-size:10px;color:var(--gray);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

.detail-body{display:grid;grid-template-columns:1fr 320px;gap:32px}
.detail-content{min-width:0}
.detail-sidebar{display:flex;flex-direction:column;gap:20px}

/* Elevation Chart */
.elevation-chart{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px;margin-bottom:24px}
.elevation-chart h3{font-family:var(--font-heading);font-size:22px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.elevation-chart canvas{width:100%;height:200px;display:block}

/* Course Highlights */
.course-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}
.highlight-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:16px;text-align:center;transition:border-color var(--transition)}
.highlight-card:hover{border-color:rgba(255,77,0,0.3)}
.highlight-card .hl-icon{font-size:28px;margin-bottom:8px}
.highlight-card .hl-name{font-weight:700;font-size:14px;color:var(--white);margin-bottom:4px}
.highlight-card .hl-desc{font-size:12px;color:var(--gray);line-height:1.5}

/* Reviews */
.review-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px;margin-bottom:12px}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.review-avatar{width:36px;height:36px;border-radius:50%;background:var(--dark-surface);display:flex;align-items:center;justify-content:center;font-size:16px}
.review-info .review-name{font-weight:700;font-size:14px;color:var(--white)}
.review-info .review-time{font-size:12px;color:var(--gray)}
.review-stars{color:var(--yellow);font-size:14px;letter-spacing:2px;margin-bottom:8px}
.review-text{font-size:14px;color:var(--gray-light);line-height:1.6}

/* Sidebar Cards */
.sidebar-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px}
.sidebar-card h3{font-family:var(--font-heading);font-size:20px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}

/* Weather */
.weather-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--dark-border);font-size:13px;color:var(--gray)}
.weather-row:last-child{border-bottom:none}
.weather-row .wr-label{font-weight:500}
.weather-row .wr-value{color:var(--white);font-weight:600}

/* Mini Chat (sidebar) */
.mini-msg{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px;font-size:13px}
.mini-msg .mm-avatar{width:24px;height:24px;border-radius:50%;background:var(--dark-surface);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.mini-msg .mm-text{color:var(--gray-light);line-height:1.4}
.mini-msg .mm-name{font-weight:700;color:var(--white);margin-right:4px}

/* Similar Races */
.similar-race{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--dark-border);transition:color var(--transition)}
.similar-race:last-child{border-bottom:none}
.similar-race .sr-flag{font-size:20px}
.similar-race .sr-info{flex:1;min-width:0}
.similar-race .sr-name{font-size:14px;font-weight:600;color:var(--white)}
.similar-race .sr-date{font-size:12px;color:var(--gray)}
.similar-race:hover .sr-name{color:var(--orange)}

/* Explore by Region */
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px}
.region-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:24px;transition:all var(--transition);cursor:pointer;text-decoration:none;color:var(--white)}
.region-card:hover{border-color:var(--orange);transform:translateY(-3px);color:var(--white)}
.region-card .region-emoji{font-size:32px;margin-bottom:12px;display:block}
.region-card h3{font-family:var(--font-heading);font-size:22px;font-weight:400;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.region-card .region-stat{font-family:var(--font-mono);font-size:12px;color:var(--gray);text-transform:uppercase;letter-spacing:1px}

/* Community Preview */
.community-preview{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:32px;max-width:600px;margin:0 auto}
.community-preview .preview-msg{display:flex;gap:10px;align-items:flex-start;margin-bottom:16px}
.community-preview .preview-msg:last-child{margin-bottom:0}
.community-preview .pm-avatar{width:32px;height:32px;border-radius:50%;background:var(--dark-surface);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.community-preview .pm-content{flex:1}
.community-preview .pm-name{font-weight:700;font-size:13px;color:var(--white);margin-bottom:2px}
.community-preview .pm-text{font-size:13px;color:var(--gray);line-height:1.5}

/* ==============================
   RESPONSIVE: TABLET
   ============================== */
@media(max-width:1024px){
  .hero-title{font-size:64px}
  .marathon-grid-3{grid-template-columns:repeat(2,1fr)}
  .marathon-grid-4{grid-template-columns:repeat(2,1fr)}
  .card-grid-3{grid-template-columns:repeat(2,1fr)}
  .card-grid-4{grid-template-columns:repeat(2,1fr)}
  .calendar-grid{grid-template-columns:repeat(3,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .details-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .popular-countries-grid{grid-template-columns:repeat(3,1fr)}
  .country-cards{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .about-cards{grid-template-columns:repeat(2,1fr)}
  .community-layout{grid-template-columns:200px 1fr}
  .community-members{display:none}
  .detail-body{grid-template-columns:1fr}
  .detail-stats-row{grid-template-columns:repeat(2,1fr)}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .profile-stats-grid{grid-template-columns:repeat(2,1fr)}
}

/* ==============================
   RESPONSIVE: MOBILE
   ============================== */
@media(max-width:768px){
  .main-content{margin-top:72px}
  .mobile-menu-btn{display:flex}
  .main-nav{display:none;position:absolute;top:72px;left:0;right:0;background:rgba(10,10,10,0.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--dark-border);flex-direction:column;padding:12px 24px;box-shadow:var(--shadow-card)}
  .main-nav.active{display:flex}
  .main-nav a{padding:14px 0;font-size:16px;border-bottom:1px solid var(--dark-border)}
  .main-nav a:last-child{border-bottom:none}
  .header-search{display:none}

  .hero{padding:120px 0 80px}
  .hero-title{font-size:48px}
  .hero-subtitle{font-size:16px}
  .hero-search-inner{flex-direction:column;border-radius:var(--radius)}
  .hero-search input{padding:16px 16px 16px 44px;border-bottom:1px solid var(--dark-border)}
  .hero-search-icon{left:14px}
  .hero-search button{border-radius:var(--radius-sm);margin:8px}

  .section{padding:56px 0}
  .section-title{font-size:36px}
  .section-subtitle{font-size:15px}
  .section-header{flex-direction:column;align-items:flex-start;gap:8px}

  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .stat-number{font-size:36px}

  .features-grid{grid-template-columns:1fr;gap:16px}
  .popular-countries-grid{grid-template-columns:repeat(2,1fr)}

  .marathon-grid-3,.marathon-grid-4{grid-template-columns:1fr}
  .card-grid-3,.card-grid-4{grid-template-columns:1fr}
  .country-cards{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .calendar-grid{grid-template-columns:repeat(2,1fr)}
  .key-facts{grid-template-columns:1fr}
  .details-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .about-cards{grid-template-columns:1fr}
  .community-layout{grid-template-columns:1fr}
  .community-sidebar{display:none}
  .community-members{display:none}
  .region-grid{grid-template-columns:1fr}
  .profile-header{flex-direction:column;text-align:center}
  .profile-stats-grid{grid-template-columns:repeat(2,1fr)}
  .course-highlights{grid-template-columns:1fr}
  .detail-stats-row{grid-template-columns:repeat(2,1fr)}
  .settings-grid{grid-template-columns:1fr}

  .marathon-layout{flex-direction:column;padding:24px 0}
  .marathon-sidebar{width:100%}

  .search-fields{flex-direction:column}
  .search-field{min-width:100%}

  .page-title{font-size:36px}
  .content-page .page-title{font-size:36px}
  .marathon-title{font-size:36px}

  .newsletter-form{flex-direction:column;border-radius:var(--radius)}
  .newsletter-form input{border-bottom:1px solid var(--dark-border)}
  .newsletter-form button{margin:8px;border-radius:var(--radius-sm)}

  .footer-grid{grid-template-columns:1fr;gap:28px}
  .pagination{flex-wrap:wrap}
}

/* ==============================
   RESPONSIVE: SMALL MOBILE
   ============================== */
@media(max-width:480px){
  .hero-title{font-size:36px}
  .hero-subtitle{font-size:15px}
  .hero-badge{font-size:10px;padding:6px 16px;letter-spacing:2px}
  .calendar-grid{grid-template-columns:1fr}
  .hero-quick-links a{font-size:13px;padding:8px 16px}
  .popular-countries-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .marathon-card-body{flex-direction:column;gap:8px}
  .marathon-card-date{display:flex;align-items:center;gap:8px;text-align:left}
  .marathon-card-date .date-day{font-size:24px}
}

/* ==============================
   PRINT
   ============================== */
/* ---------- Beta Badge ---------- */
.beta-badge{font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;background:var(--orange);color:var(--white);padding:2px 6px;border-radius:4px;vertical-align:middle;margin-left:4px;font-weight:700}
.hero-badge .beta-badge{font-size:10px;padding:3px 8px;margin-left:8px}

/* ---------- Trust Note ---------- */
.trust-note{text-align:center;font-size:13px;color:var(--gray);margin-top:8px;font-family:var(--font-mono);letter-spacing:0.3px}

/* ---------- Coming Soon Placeholder ---------- */
.coming-soon-placeholder{padding:24px;background:var(--dark-surface);border:1px dashed var(--dark-border);border-radius:var(--radius);text-align:center}
.coming-soon-placeholder p{color:var(--gray);font-size:14px;margin:0}

/* ---------- Coming Soon Page ---------- */
.coming-soon-page{text-align:center;max-width:640px;margin:0 auto;padding:32px 0}
.coming-soon-icon{font-size:64px;margin-bottom:16px}
.coming-soon-page h1{font-family:var(--font-heading);font-size:48px;font-weight:400;letter-spacing:2px;text-transform:uppercase;margin:8px 0 16px}
.coming-soon-desc{font-size:16px;color:var(--gray-light);line-height:1.7;max-width:500px;margin:0 auto 32px}
.coming-soon-features{text-align:left;display:flex;flex-direction:column;gap:20px;margin-bottom:40px}
.csf-item{display:flex;gap:16px;align-items:flex-start;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px}
.csf-icon{font-size:28px;flex-shrink:0;margin-top:2px}
.csf-item h4{font-family:var(--font-heading);font-size:18px;font-weight:400;letter-spacing:0.5px;text-transform:uppercase;margin-bottom:4px}
.csf-item p{font-size:14px;color:var(--gray);margin:0;line-height:1.5}
.coming-soon-cta{background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:var(--radius);padding:24px;text-align:center}
.coming-soon-cta p{color:var(--gray-light);font-size:14px;margin-bottom:12px}
.coming-soon-cta .newsletter-form{max-width:400px;margin:0 auto}

/* ---------- Coming Soon Block (homepage) ---------- */
.coming-soon-block{text-align:center;padding:48px 24px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-lg);max-width:640px;margin:0 auto}
.coming-soon-block .section-subtitle{max-width:480px;margin:0 auto 24px}

/* ---------- Future Pricing Card ---------- */
.pricing-card-future{opacity:0.6;position:relative}
.pricing-card-future::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);pointer-events:none}

/* ---------- Button Outline ---------- */
.btn-outline{display:inline-block;padding:12px 32px;border:1px solid var(--dark-border);color:var(--gray-light);border-radius:var(--radius-full);font-family:var(--font-heading);font-size:16px;letter-spacing:1px;text-transform:uppercase;transition:all var(--transition);text-decoration:none}
.btn-outline:hover{border-color:var(--orange);color:var(--orange)}

/* ---------- Results Header (search/listing) ---------- */
.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.sort-control{display:flex;align-items:center;gap:8px}
.sort-control label{font-size:13px;color:var(--gray);font-family:var(--font-mono);letter-spacing:0.3px;text-transform:uppercase;white-space:nowrap}
.form-input-sm{padding:6px 12px;font-size:13px;min-width:150px}

/* ---------- Card Tags (BQ, Certified, Participants) ---------- */
.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.card-tag{display:inline-flex;align-items:center;font-size:11px;color:var(--gray-light);background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:var(--radius-full);padding:2px 10px;font-family:var(--font-mono);letter-spacing:0.3px;text-transform:uppercase}
.card-tag-bq{color:var(--yellow);border-color:rgba(255,214,0,0.3);background:rgba(255,214,0,0.08)}
.card-tag-cert{color:var(--green);border-color:rgba(0,230,118,0.3);background:rgba(0,230,118,0.08)}

/* ---------- Card Badge: Closing Soon ---------- */
.card-badge-closing{background:var(--orange)}

/* ---------- Chart Disclaimer ---------- */
.chart-disclaimer{font-size:12px;color:var(--gray-dark);text-align:center;margin-top:8px;font-style:italic}

/* ---------- Registration Timeline ---------- */
.reg-timeline{margin-top:8px}
.reg-timeline-bar{width:100%;height:6px;background:var(--dark-surface);border-radius:3px;overflow:hidden}
.reg-timeline-fill{height:100%;background:var(--orange);border-radius:3px;transition:width 0.3s ease}
.reg-timeline-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--gray);font-family:var(--font-mono);letter-spacing:0.3px}

@media print{
  .site-header,.site-footer,.ad-slot,.mobile-menu-btn,.hero-search,.section-cta,.pagination,.noise-overlay{display:none !important}
  body{font-size:12pt;color:#000;background:#fff}
  .marathon-layout{flex-direction:column}
  .marathon-sidebar{width:100%}
}
