/* ════════════════════════════════════════════
   NOBIRU — V12
   Design System: Swiss Precision × LinkedIn Pro
   ════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=DM+Serif+Display:ital@0;1&display=swap');
/* Manrope = font principal (igual que index.html) */

:root {
  --ink:#0a0a0f; --ink-2:#1a1a2e; --muted:#6b7280; --muted-2:#9ca3af;
  --line:rgba(10,10,15,.1); --line-dark:rgba(255,255,255,.12);
  --bg:#ffffff; --bg-soft:#f8f8fa; --bg-soft-2:#f1f1f5;
  --dark:#0a0a0f; --gold:#b8922a; --gold-2:#d4a843; --gold-bg:rgba(184,146,42,.08);
  --green:#166534; --green-bg:#dcfce7; --red:#ef4444; --red-bg:#fee2e2;
  --blue:#1e40af; --blue-bg:#dbeafe;
  --serif:'DM Serif Display',Georgia,serif; --sans:'Manrope',system-ui,sans-serif;
  --max:1200px; --max-sm:760px; --r:14px; --r-lg:22px;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow:0 4px 24px rgba(0,0,0,.07); --shadow-lg:0 16px 64px rgba(0,0,0,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;scrollbar-gutter:stable;}
body{font-family:var(--sans);font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg);}
a{color:inherit;text-decoration:none;}img{display:block;max-width:100%;}
button{cursor:pointer;font-family:inherit;border:none;background:none;}
input,select,textarea{font-family:inherit;}ul{list-style:none;}
.container{max-width:var(--max);margin:0 auto;padding:0 32px;}
.container-sm{max-width:var(--max-sm);margin:0 auto;padding:0 32px;}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s;}
.nav.scrolled{border-color:var(--line);box-shadow:0 4px 32px rgba(0,0,0,.06);}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 32px;height:66px;display:flex;align-items:center;gap:28px;}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.brand-mark{font-family:var(--serif);font-size:18px;color:var(--gold);letter-spacing:.05em;}
.brand-name{font-size:13.5px;font-weight:500;color:var(--ink);}
.nav-links{display:flex;gap:24px;flex:1;}
.nav-links a{font-size:13px;color:var(--muted);transition:color .2s;}
.nav-links a:hover{color:var(--ink);}
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.lang-selector{position:relative;}
.lang-btn{display:flex;align-items:center;gap:5px;padding:6px 10px;border:1px solid var(--line);border-radius:8px;font-size:12px;color:var(--muted);transition:all .2s;background:transparent;}
.lang-btn:hover{border-color:var(--ink);color:var(--ink);}
.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;min-width:158px;display:none;flex-direction:column;gap:2px;z-index:200;}
.lang-dropdown.open{display:flex;}
.lang-option{padding:8px 12px;border-radius:8px;font-size:13px;color:var(--ink);text-align:left;transition:background .15s;}
.lang-option:hover{background:var(--bg-soft);}
.lang-option.active{background:var(--gold-bg);color:var(--gold);font-weight:500;}
.nav-mobile-toggle{display:none;flex-direction:column;gap:5px;padding:6px;margin-left:auto;}
.nav-mobile-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);border-radius:2px;transition:all .25s;}
.nav-mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px);}
.nav-mobile-toggle.open span:nth-child(2){opacity:0;}
.nav-mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px);}
.nav-mobile{display:none;flex-direction:column;gap:4px;padding:12px 24px 20px;border-top:1px solid var(--line);}
.nav-mobile.open{display:flex;}
.nav-mobile a{padding:10px 0;font-size:15px;color:var(--muted);border-bottom:1px solid var(--line);}
.nav-mobile a:last-child{border:none;margin-top:8px;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;border-radius:999px;font-size:13.5px;font-weight:500;transition:all .2s var(--ease);cursor:pointer;white-space:nowrap;}
.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none;}
.btn-primary{background:var(--ink);color:#fff;border:1.5px solid var(--ink);}
.btn-primary:hover{background:var(--ink-2);transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.16);}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--line);}
.btn-outline:hover{border-color:var(--ink);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--muted);padding:10px 14px;border:none;}
.btn-ghost:hover{color:var(--ink);}
.btn-gold{background:var(--gold);color:#fff;border:1.5px solid var(--gold);}
.btn-gold:hover{background:#a07a22;}
.btn-danger{background:var(--red);color:#fff;border:1.5px solid var(--red);}
.btn-danger:hover{background:#7f1d1d;}
.btn-sm{padding:7px 16px;font-size:12.5px;}
.btn-lg{padding:14px 28px;font-size:15px;}
.btn-full{width:100%;}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3);border-radius:999px;padding:11px 22px;font-size:13.5px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6);}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.form-label{font-size:13px;font-weight:500;color:var(--ink);}
.form-label span{color:var(--muted);font-weight:400;margin-left:4px;}
.form-input,.form-select,.form-textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-family:var(--sans);color:var(--ink);background:var(--bg);transition:border-color .2s,box-shadow .2s;appearance:none;-webkit-appearance:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(10,10,15,.07);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted-2);}
.form-textarea{resize:vertical;min-height:100px;line-height:1.6;}
.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
.form-hint{font-size:12px;color:var(--muted);line-height:1.5;}
.form-error{font-size:12px;color:var(--red);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;}
.panel{background:var(--bg-soft);border-radius:var(--r-lg);padding:28px;}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:120px 32px 80px;max-width:var(--max);margin:0 auto;position:relative;}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.hero-kicker{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}
.hero-title{font-family:var(--serif);font-size:clamp(48px,6vw,76px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin-bottom:24px;}
.hero-title em{font-style:italic;color:var(--gold);}
.hero-lead{font-size:17px;line-height:1.7;color:var(--muted);max-width:52ch;margin-bottom:36px;font-weight:300;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px;}
.hero-note{font-size:12.5px;color:var(--muted-2);}
.hero-visual{display:flex;justify-content:center;align-items:center;}
.hero-card-stack{position:relative;width:320px;height:400px;}
.profile-card{position:absolute;background:#fff;border:1px solid var(--line);border-radius:20px;padding:20px;display:flex;align-items:center;gap:14px;box-shadow:0 20px 60px rgba(0,0,0,.08);width:260px;}
.profile-card--1{top:20px;left:0;z-index:3;animation:float1 6s ease-in-out infinite;}
.profile-card--2{top:140px;right:0;z-index:2;animation:float2 7s ease-in-out infinite;}
.profile-card--3{top:260px;left:20px;z-index:1;animation:float3 8s ease-in-out infinite;}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes float3{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.pc-avatar{width:44px;height:44px;border-radius:12px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.pc-sport{font-size:13.5px;font-weight:600;margin-bottom:2px;}
.pc-country{font-size:12px;color:var(--muted);margin-bottom:6px;}
.pc-badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:var(--gold);background:var(--gold-bg);padding:3px 8px;border-radius:999px;}
.pc-badge::before{content:'✓';}
.stat-bubble{position:absolute;background:var(--ink);color:#fff;border-radius:14px;padding:10px 16px;text-align:center;box-shadow:0 12px 32px rgba(0,0,0,.2);z-index:4;}
.stat-bubble--top{top:0;right:-10px;animation:float2 5s ease-in-out infinite;}
.stat-bubble--bottom{bottom:10px;right:10px;animation:float1 6s ease-in-out infinite;}
.sb-num{display:block;font-family:var(--serif);font-size:22px;line-height:1;}
.sb-label{display:block;font-size:10px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;}
.scroll-indicator{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--ink),transparent);animation:scrollLine 2s ease-in-out infinite;}
@keyframes scrollLine{0%,100%{opacity:.3}50%{opacity:1}}

/* ── INDEX SECTIONS ── */
.trust-bar{padding:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.trust-bar .container{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.trust-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);flex-shrink:0;}
.trust-logos{display:flex;gap:32px;flex-wrap:wrap;}
.trust-logo-placeholder{font-size:12px;font-weight:600;color:var(--muted-2);opacity:.5;}
.section{padding:96px 0;}
.section--dark{background:var(--dark);color:#fff;}
.section-kicker{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.section-kicker--light{color:var(--gold-2);}
.section-title{font-family:var(--serif);font-size:clamp(32px,4vw,48px);line-height:1.1;letter-spacing:-.02em;color:var(--ink);max-width:20ch;margin-bottom:20px;}
.section-title--light{color:#fff;}
.section-lead{font-size:16px;line-height:1.7;color:var(--muted);max-width:48ch;margin-bottom:32px;font-weight:300;}
.section-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.section-left{position:sticky;top:100px;}
.opp-item{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--line);transition:padding-left .2s;}
.opp-item:first-child{border-top:1px solid var(--line);}
.opp-item:hover{padding-left:8px;}
.opp-icon{font-size:20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-soft);border-radius:10px;flex-shrink:0;}
.opp-type{font-size:14px;font-weight:600;margin-bottom:3px;}
.opp-desc{font-size:13px;color:var(--muted);line-height:1.5;}
.orgs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;}
.org-card{border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:32px;background:rgba(255,255,255,.04);transition:background .2s;}
.org-card:hover{background:rgba(255,255,255,.07);}
.org-card--featured{border-color:var(--gold);background:rgba(184,146,42,.06);}
.org-card-icon{font-size:28px;margin-bottom:16px;}
.org-card h3{font-family:var(--serif);font-size:22px;color:#fff;margin-bottom:12px;}
.org-card p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:20px;font-weight:300;}
.org-list{display:flex;flex-direction:column;gap:8px;}
.org-list li{font-size:13.5px;color:rgba(255,255,255,.75);padding-left:18px;position:relative;}
.org-list li::before{content:'→';position:absolute;left:0;color:var(--gold-2);font-size:11px;top:2px;}
.privacy-promise{display:flex;gap:20px;align-items:flex-start;margin-top:48px;padding:28px 32px;border:1px solid var(--line-dark);border-radius:var(--r-lg);background:rgba(255,255,255,.03);}
.pp-icon{font-size:28px;flex-shrink:0;}
.pp-content h4{font-size:15px;font-weight:600;color:#fff;margin-bottom:6px;}
.pp-content p{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.7;font-weight:300;}
.how-tabs{display:flex;gap:4px;margin:40px 0 48px;background:var(--bg-soft);border-radius:12px;padding:4px;width:fit-content;}
.how-tab{padding:10px 24px;border-radius:9px;font-size:13.5px;color:var(--muted);transition:all .2s;}
.how-tab.active{background:#fff;color:var(--ink);font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.08);}
.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.how-steps.hidden{display:none;}
.step-num{font-family:var(--serif);font-size:40px;color:var(--line);line-height:1;margin-bottom:16px;}
.step-content h4{font-size:15px;font-weight:600;margin-bottom:8px;}
.step-content p{font-size:13.5px;color:var(--muted);line-height:1.65;font-weight:300;}
.stats-section{padding:72px 0;background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.stat-item{padding:0 32px;border-right:1px solid var(--line);text-align:center;}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:var(--serif);font-size:48px;line-height:1;letter-spacing:-.03em;margin-bottom:8px;}
.stat-label{font-size:13px;color:var(--muted);font-weight:300;}
.cta-section{padding:96px 0;}
.cta-box{position:relative;overflow:hidden;background:var(--ink);border-radius:28px;padding:72px;display:flex;align-items:center;}
.cta-content{position:relative;z-index:2;}
.cta-content h2{font-family:var(--serif);font-size:clamp(32px,4vw,48px);color:#fff;line-height:1.1;letter-spacing:-.02em;margin-bottom:16px;}
.cta-content p{font-size:16px;color:rgba(255,255,255,.6);max-width:48ch;line-height:1.7;margin-bottom:36px;font-weight:300;}
.cta-buttons{display:flex;gap:12px;flex-wrap:wrap;}
.cta-buttons .btn-primary{background:#fff;color:var(--ink);border-color:#fff;}
.cta-buttons .btn-primary:hover{background:var(--bg-soft);}
.cta-buttons .btn-outline{color:#fff;border-color:rgba(255,255,255,.3);}
.cta-buttons .btn-outline:hover{border-color:#fff;}
.cta-decoration{position:absolute;right:-60px;top:50%;transform:translateY(-50%);}
.deco-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.07);}
.deco-ring--1{width:300px;height:300px;top:-150px;left:-150px;}
.deco-ring--2{width:500px;height:500px;top:-250px;left:-250px;}
.deco-ring--3{width:700px;height:700px;top:-350px;left:-350px;}

/* ── FOOTER ── */
.footer{padding:64px 0 32px;border-top:1px solid var(--line);}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:64px;margin-bottom:48px;align-items:start;}
.footer-tagline{font-size:13px;color:var(--muted);margin-top:12px;max-width:32ch;line-height:1.6;font-weight:300;}
.footer-links{display:flex;gap:48px;}
.footer-col{display:flex;flex-direction:column;gap:10px;}
.footer-col-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink);margin-bottom:4px;}
.footer-col a{font-size:13.5px;color:var(--muted);transition:color .2s;}
.footer-col a:hover{color:var(--ink);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--line);font-size:12px;color:var(--muted-2);flex-wrap:wrap;gap:8px;}

/* ── AUTH PAGES ── */
.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;}
.auth-left{background:var(--dark);display:flex;flex-direction:column;justify-content:space-between;padding:48px;}
.auth-left-content{flex:1;display:flex;flex-direction:column;justify-content:center;padding:32px 0;}
.auth-left h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);color:#fff;line-height:1.1;letter-spacing:-.02em;margin-bottom:16px;}
.auth-left h2 em{font-style:italic;color:var(--gold-2);}
.auth-left p{font-size:15px;color:rgba(255,255,255,.55);line-height:1.7;max-width:40ch;font-weight:300;}
.auth-left-features{display:flex;flex-direction:column;gap:16px;margin-top:40px;}
.auth-feature{display:flex;align-items:flex-start;gap:12px;}
.auth-feature-icon{font-size:18px;margin-top:2px;flex-shrink:0;}
.auth-feature-text h5{font-size:14px;font-weight:500;color:#fff;margin-bottom:2px;}
.auth-feature-text p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.5;}
.auth-left-footer{font-size:12px;color:rgba(255,255,255,.3);}
.auth-right{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--bg);}
.auth-form-wrap{width:100%;max-width:440px;}
.auth-form-wrap h1{font-family:var(--serif);font-size:28px;letter-spacing:-.02em;margin-bottom:6px;}
.auth-subtitle{font-size:14px;color:var(--muted);margin-bottom:32px;font-weight:300;}
.auth-footer-link{text-align:center;margin-top:24px;font-size:13px;color:var(--muted);}
.auth-footer-link a{color:var(--ink);font-weight:500;text-decoration:underline;}
#msg,.msg-box{font-size:13.5px;margin-top:12px;min-height:20px;}
.msg-error{color:var(--red);}
.msg-success{color:var(--green);}
.role-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px;}
.role-card{border:1.5px solid var(--line);border-radius:var(--r);padding:18px 14px;text-align:center;cursor:pointer;transition:all .2s;}
.role-card:hover{border-color:var(--ink);}
.role-card.active{border-color:var(--ink);background:var(--ink);color:#fff;}
.role-card-icon{font-size:24px;margin-bottom:8px;}
.role-card-label{font-size:13px;font-weight:600;}
.role-card-desc{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4;}
.role-card.active .role-card-desc{color:rgba(255,255,255,.6);}
.role-fields{display:none;}
.role-fields.visible{display:block;}

/* ── STATUS PAGES ── */
.status-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;}
.status-card{max-width:520px;width:100%;text-align:center;}
.status-icon{font-size:64px;margin-bottom:24px;}
.status-card h1{font-family:var(--serif);font-size:32px;letter-spacing:-.02em;margin-bottom:12px;}
.status-card p{font-size:15px;color:var(--muted);line-height:1.7;font-weight:300;margin-bottom:28px;}
.status-steps{text-align:left;background:var(--bg-soft);border-radius:var(--r-lg);padding:24px;margin:28px 0;}
.status-step{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);align-items:flex-start;}
.status-step:last-child{border-bottom:none;}
.status-step-num{width:28px;height:28px;border-radius:50%;background:var(--muted-2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;}
.status-step-num.done{background:var(--green);}
.status-step-num.active{background:var(--gold);}
.status-step-text h5{font-size:13.5px;font-weight:600;margin-bottom:2px;}
.status-step-text p{font-size:12.5px;color:var(--muted);}
.upload-area{border:2px dashed var(--line);border-radius:var(--r);padding:32px;text-align:center;cursor:pointer;transition:all .2s;}
.upload-area:hover,.upload-area.drag-over{border-color:var(--ink);background:var(--bg-soft);}
.upload-area input[type=file]{display:none;}
.upload-icon{font-size:32px;margin-bottom:12px;}
.upload-label{font-size:14px;font-weight:500;margin-bottom:4px;}
.upload-hint{font-size:12px;color:var(--muted);}
.upload-preview{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-soft);border-radius:10px;margin-top:10px;font-size:13px;}

/* ── DASHBOARD ── */
.dash-layout{display:flex;min-height:100vh;padding-top:66px;}
.dash-sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid var(--line);position:fixed;top:66px;left:0;bottom:0;overflow-y:auto;padding:20px 0;display:flex;flex-direction:column;}
.dash-sidebar-section{padding:6px 12px;margin-bottom:4px;}
.dash-sidebar-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);padding:0 8px;margin-bottom:6px;}
.dash-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:15px;color:var(--muted);transition:all .2s;cursor:pointer;width:100%;text-align:left;}
.dash-nav-item:hover{background:var(--bg-soft);color:var(--ink);}
.dash-nav-item.active{background:var(--ink);color:#fff;}
.dash-nav-item.active .nav-badge{background:rgba(255,255,255,.2);color:#fff;}
.dash-nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;min-width:18px;text-align:center;}
.dash-sidebar-footer{margin-top:auto;padding:16px 12px;border-top:1px solid var(--line);}
.dash-user-info{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;}
.dash-user-avatar{width:34px;height:34px;border-radius:50%;background:var(--bg-soft-2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--ink);flex-shrink:0;}
.dash-user-name{font-size:13px;font-weight:500;color:var(--ink);}
.dash-user-role{font-size:11px;color:var(--muted);text-transform:capitalize;}
.dash-main{flex:1;margin-left:240px;padding:32px;background:var(--bg-soft);min-height:calc(100vh - 66px);}
.dash-section{display:none;}
.dash-section.active{display:block;}
.dash-header{margin-bottom:28px;}
.dash-header h1{font-family:var(--sans);font-size:28px;font-weight:800;letter-spacing:-.03em;margin-bottom:4px;}
.dash-header p{font-size:14px;color:var(--muted);font-weight:300;}
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.dash-stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;}
.dash-stat-num{font-family:var(--sans);font-size:36px;font-weight:800;line-height:1;margin-bottom:4px;}
.dash-stat-label{font-size:12.5px;color:var(--muted);}
.table-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;}
.table-toolbar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
.table-toolbar-title{font-size:15px;font-weight:600;flex:1;}
.table-search{padding:8px 14px;border:1px solid var(--line);border-radius:8px;font-size:13px;width:220px;font-family:var(--sans);}
.table-search:focus{outline:none;border-color:var(--ink);}
.table-overflow{overflow-x:auto;}
.data-table{width:100%;border-collapse:collapse;}
.data-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:12px 20px;text-align:left;background:var(--bg-soft);border-bottom:1px solid var(--line);white-space:nowrap;}
.data-table td{padding:14px 20px;font-size:13.5px;border-bottom:1px solid var(--line);}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--bg-soft);}
.table-empty{padding:48px;text-align:center;color:var(--muted);font-size:14px;}
.opp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
.opp-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:18px;padding:24px;transition:box-shadow .22s,transform .22s;box-shadow:0 1px 4px rgba(0,0,0,.04);display:flex;flex-direction:column;}
.opp-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.1);transform:translateY(-3px);}
.opp-card-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#67a3fb;margin-bottom:14px;display:flex;align-items:center;gap:6px;}
.opp-card-type::before{content:'';display:block;width:20px;height:3px;border-radius:2px;background:linear-gradient(90deg,#67a3fb,#4285f4);flex-shrink:0;}
.opp-card-title{font-size:16px;font-weight:800;margin-bottom:6px;line-height:1.3;letter-spacing:-.03em;color:#0c0c14;}
.opp-card-org{font-size:13px;color:#6b7280;margin-bottom:14px;font-weight:500;}
.opp-card-meta{display:flex;gap:12px;font-size:12px;color:var(--muted);margin-bottom:16px;flex-wrap:wrap;}
.opp-card-footer{display:flex;justify-content:space-between;align-items:center;}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px;}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:var(--r-lg);padding:32px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;}
.modal-title{font-family:var(--sans);font-size:22px;font-weight:800;letter-spacing:-.02em;}
.modal-close{font-size:22px;color:var(--muted);cursor:pointer;line-height:1;}
.modal-close:hover{color:var(--ink);}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);}
.filter-row{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.filter-btn{padding:7px 16px;border-radius:999px;border:1px solid var(--line);font-size:12.5px;color:var(--muted);background:#fff;cursor:pointer;transition:all .2s;}
.filter-btn:hover{border-color:var(--ink);color:var(--ink);}
.filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.verify-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,var(--gold-bg),rgba(184,146,42,.02));border:1px solid rgba(184,146,42,.3);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:24px;}
.verify-banner-icon{font-size:28px;flex-shrink:0;}
.verify-banner-text h4{font-size:14px;font-weight:600;margin-bottom:3px;}
.verify-banner-text p{font-size:13px;color:var(--muted);line-height:1.5;}
.profile-avatar-row{display:flex;align-items:center;gap:20px;margin-bottom:28px;}
.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--bg-soft-2);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:var(--ink);flex-shrink:0;}

/* ── BADGE SYSTEM ── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;}
.badge-gold{color:var(--gold);background:var(--gold-bg);}
.badge-green{color:var(--green);background:var(--green-bg);}
.badge-red{color:var(--red);background:var(--red-bg);}
.badge-blue{color:var(--blue);background:var(--blue-bg);}
.badge-gray{color:var(--muted);background:var(--bg-soft-2);}

/* ── ANIMATIONS ── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;}.hero-visual{display:none;}
  .section-split{grid-template-columns:1fr;gap:40px;}.section-left{position:static;}
  .how-steps{grid-template-columns:repeat(2,1fr);}.orgs-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}.dash-stats{grid-template-columns:repeat(2,1fr);}
  .auth-page{grid-template-columns:1fr;}.auth-left{display:none;}
}
@media(max-width:768px){
  .container,.container-sm{padding:0 20px;}.nav-inner{padding:0 20px;}
  .nav-links,.nav-actions .btn-ghost{display:none;}.nav-mobile-toggle{display:flex;}
  .hero{padding:100px 20px 60px;}.section{padding:64px 0;}
  .how-steps{grid-template-columns:1fr;}.stats-grid{grid-template-columns:1fr 1fr;}
  .cta-box{padding:40px 28px;}.cta-buttons,.hero-ctas{flex-direction:column;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}.footer-links{gap:32px;}
  .footer-bottom,.privacy-promise{flex-direction:column;}
  .dash-main{margin-left:0;padding:20px;}
  .dash-stats{grid-template-columns:1fr 1fr;}.form-row{grid-template-columns:1fr;}
  .role-selector{grid-template-columns:1fr;}
}


/* ════════════════════════════════════════════
   DASHBOARD — PREMIUM REDESIGN
   ════════════════════════════════════════════ */

/* Layout */
.dash-layout { display:flex; min-height:100vh; padding-top:66px; }
.dash-sidebar {
  width:160px; flex-shrink:0;
  background: linear-gradient(180deg, #0c1929 0%, #0f2240 100%);
  border-right: none;
  position:fixed; top:66px; left:0; bottom:0;
  overflow-y:auto; padding:16px 0;
  display:flex; flex-direction:column;
  box-shadow: 4px 0 24px rgba(0,0,0,.15);
}
.dash-sidebar-section { padding:6px 16px; margin-bottom:8px; }
.dash-sidebar-label {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.14em; color:rgba(255,255,255,.25);
  padding:0 10px; margin-bottom:8px; display:block;
}
.dash-nav-item {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px; border-radius:12px;
  font-size:14px; font-weight:500;
  color:rgba(255,255,255,.55);
  transition:all .18s; cursor:pointer;
  width:100%; text-align:left; border:none;
  background:transparent; letter-spacing:-.01em;
}
.dash-nav-item:hover { background:rgba(255,255,255,.07); color:rgba(255,255,255,.9); }
.dash-nav-item.active {
  background: linear-gradient(135deg, #67a3fb 0%, #4285f4 100%);
  color:#fff; font-weight:600;
  box-shadow: 0 4px 16px rgba(103,163,251,.35);
}
.dash-nav-item.active .nav-badge { background:#ef4444; color:#fff; }
.dash-nav-icon { font-size:17px; width:22px; text-align:center; flex-shrink:0; }
.nav-badge {
  margin-left:auto; background:var(--red); color:#fff;
  font-size:10px; font-weight:700; padding:2px 7px;
  border-radius:999px; min-width:18px; text-align:center;
}
.dash-sidebar-footer {
  margin-top:auto; padding:16px;
  border-top:1px solid rgba(255,255,255,.08);
}
.dash-user-info { display:flex; align-items:center; gap:10px; padding:10px; border-radius:12px; background:rgba(255,255,255,.05); }
.dash-user-avatar {
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg,#67a3fb,#4285f4);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:700; color:#fff; flex-shrink:0;
}
.dash-user-name { font-size:13px; font-weight:600; color:rgba(255,255,255,.9); }
.dash-user-role { font-size:11px; color:rgba(255,255,255,.4); text-transform:capitalize; }

/* Main content */
.dash-main {
  flex:1; margin-left:160px; padding:24px 28px;
  background: #f7f7f9;
  min-height:calc(100vh - 66px);
}
.dash-section { display:none; }
.dash-section.active { display:block; animation: fadeIn .25s ease; position: relative; z-index: 0; }
@keyframes fadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }

/* Page headers */
.dash-header { margin-bottom:28px; }
.dash-header h1 {
  font-size:30px; font-weight:800;
  letter-spacing:-.04em; color:#0c0c14;
  margin-bottom:4px; line-height:1.1;
}
.dash-header p { font-size:14px; color:#6b7280; font-weight:400; line-height:1.6; }

/* Stats grid */
.dash-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:28px; }
.dash-stat {
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:16px; padding:22px 24px;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  transition:box-shadow .2s;
}
.dash-stat:hover { box-shadow:0 4px 16px rgba(0,0,0,.08); }
.dash-stat-num {
  font-size:38px; font-weight:800; line-height:1;
  margin-bottom:6px; color:#0c0c14;
  letter-spacing:-.03em;
}
.dash-stat-label { font-size:12.5px; color:#6b7280; font-weight:500; }

/* Table containers */
.table-wrap {
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:16px; overflow:hidden;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.table-toolbar {
  display:flex; align-items:center; gap:12px;
  padding:18px 24px; border-bottom:1px solid rgba(0,0,0,.06);
  flex-wrap:wrap; background:#fff;
}
.table-toolbar-title { font-size:15px; font-weight:700; flex:1; letter-spacing:-.02em; color:#0c0c14; }
.table-search {
  padding:8px 14px; border:1.5px solid rgba(0,0,0,.1);
  border-radius:10px; font-size:13px; width:220px;
  font-family:inherit; background:#f7f7f9; color:#0c0c14;
  transition:border-color .2s;
}
.table-search:focus { outline:none; border-color:#67a3fb; background:#fff; }
.table-overflow { overflow-x:auto; }
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:#9ca3af; padding:12px 24px;
  text-align:left; background:#fafafa;
  border-bottom:1px solid rgba(0,0,0,.06); white-space:nowrap;
}
.data-table td { padding:15px 24px; font-size:13.5px; border-bottom:1px solid rgba(0,0,0,.04); color:#0c0c14; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:#fafafa; }
.table-empty { padding:56px; text-align:center; color:#9ca3af; font-size:14px; }

/* Opportunity cards */
.opp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:18px; }
.opp-card {
  background:#fff; border:1px solid rgba(0,0,0,.07);
  border-radius:18px; padding:26px;
  transition:box-shadow .2s, transform .2s;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.opp-card:hover { box-shadow:0 8px 32px rgba(0,0,0,.1); transform:translateY(-2px); }
.opp-card-type {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; color:#67a3fb; margin-bottom:12px;
}
.opp-card-title { font-size:16px; font-weight:700; margin-bottom:6px; line-height:1.3; letter-spacing:-.02em; color:#0c0c14; }
.opp-card-org { font-size:13px; color:#6b7280; margin-bottom:14px; font-weight:500; }
.opp-card-meta { display:flex; gap:12px; font-size:12px; color:#9ca3af; margin-bottom:18px; flex-wrap:wrap; }
.opp-card-footer { display:flex; justify-content:space-between; align-items:center; }

/* Modals */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); display:none; align-items:center; justify-content:center; z-index:1000; padding:24px; backdrop-filter:blur(4px); }
.modal-overlay.open { display:flex; }
.modal { background:#fff; border-radius:20px; padding:36px; max-width:540px; width:100%; max-height:90vh; overflow-y:auto; box-shadow:0 24px 80px rgba(0,0,0,.2); }
.modal-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:28px; }
.modal-title { font-size:22px; font-weight:800; letter-spacing:-.03em; color:#0c0c14; }
.modal-close { font-size:22px; color:#9ca3af; cursor:pointer; line-height:1; transition:color .15s; }
.modal-close:hover { color:#0c0c14; }
.modal-footer { display:flex; justify-content:flex-end; gap:10px; margin-top:28px; padding-top:22px; border-top:1px solid rgba(0,0,0,.06); }

/* Filters */
.filter-row { display:flex; gap:8px; margin-bottom:22px; flex-wrap:wrap; }
.filter-btn {
  padding:7px 16px; border-radius:999px;
  border:1.5px solid rgba(0,0,0,.1); font-size:12.5px; font-weight:500;
  color:#6b7280; background:#fff; cursor:pointer; transition:all .18s;
}
.filter-btn:hover { border-color:#0c0c14; color:#0c0c14; }
.filter-btn.active { background:#0c0c14; color:#fff; border-color:#0c0c14; }

/* Cards */
.card {
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:18px; padding:32px;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}

/* Profile */
.profile-avatar-row { display:flex; align-items:center; gap:20px; margin-bottom:28px; }
.profile-avatar {
  width:70px; height:70px; border-radius:50%;
  background:linear-gradient(135deg,#67a3fb,#4285f4);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; font-weight:700; color:#fff; flex-shrink:0;
}

/* Verify banner */
.verify-banner {
  display:flex; align-items:center; gap:16px;
  background:linear-gradient(135deg,rgba(184,146,42,.08),rgba(184,146,42,.02));
  border:1px solid rgba(184,146,42,.25); border-radius:16px;
  padding:20px 26px; margin-bottom:24px;
}
.verify-banner-icon { font-size:28px; flex-shrink:0; }
.verify-banner-text h4 { font-size:14px; font-weight:700; margin-bottom:3px; }
.verify-banner-text p { font-size:13px; color:#6b7280; line-height:1.5; }

/* Badge system */
.badge { display:inline-flex; align-items:center; padding:3px 10px; border-radius:999px; font-size:11.5px; font-weight:600; }
.badge-gold { color:#b8922a; background:rgba(184,146,42,.1); }
.badge-green { color:#166534; background:#dcfce7; }
.badge-red { color:#991b1b; background:#fee2e2; }
.badge-blue { color:#1e40af; background:#dbeafe; }
.badge-gray { color:#6b7280; background:#f3f4f6; }

/* Responsive */
@media(max-width:1024px){
  .dash-stats{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .dash-main{margin-left:0;padding:20px;}
  .dash-stats{grid-template-columns:1fr 1fr;}
}

/* ── SKELETON SCREENS ── */
@keyframes shimmer {
  0% { background-position: -600px 0; }
  100% { background-position: 600px 0; }
}
.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
  background-size: 600px 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: 8px;
}
.skeleton-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  padding: 24px;
}
.skeleton-line { height: 14px; margin-bottom: 10px; }
.skeleton-line.w-80 { width: 80%; }
.skeleton-line.w-60 { width: 60%; }
.skeleton-line.w-40 { width: 40%; }
.skeleton-title { height: 20px; width: 60%; margin-bottom: 14px; }
.skeleton-avatar { width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0; }

/* ── SECTION ENTRANCE ANIMATIONS ── */
.dash-section.active {
  animation: sectionIn .3s cubic-bezier(.22,1,.36,1) both;
  position: relative;
  z-index: 0;
}
@keyframes sectionIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Enhanced dash header */
.dash-header h1 {
  font-size: 30px;
  font-weight: 800;
  letter-spacing: -.04em;
  color: #0c0c14;
  line-height: 1.1;
  margin-bottom: 6px;
}
.dash-header p {
  font-size: 14px;
  color: #9ca3af;
  line-height: 1.6;
  font-weight: 400;
}

/* Enhanced nav for dashboards */
#mainNav {
  box-shadow: 0 1px 0 rgba(0,0,0,.06);
}

/* Improved sidebar items */
.dash-nav-item {
  font-weight: 500;
  letter-spacing: -.01em;
}
.dash-nav-item.active {
  font-weight: 700;
  letter-spacing: -.02em;
}

/* Stat hover effect */
.dash-stat {
  cursor: default;
  transition: all .2s;
}
.dash-stat:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08) !important;
}

/* Table row animation */
.data-table tbody tr {
  transition: background .15s;
}

/* ════════════════════════════════════════
   MOBILE OPTIMIZATIONS (PWA)
   ════════════════════════════════════════ */

/* Safe area insets for notched phones */
@supports (padding: env(safe-area-inset-top)) {
  nav#nav {
    padding-left: calc(16px + env(safe-area-inset-left));
    padding-right: calc(16px + env(safe-area-inset-right));
  }
  .dash-sidebar {
    padding-bottom: env(safe-area-inset-bottom);
  }
}

@media (max-width: 768px) {
  /* Nav */
  nav .nav-links { display: none; }
  nav { padding: 0 16px; height: 56px; }
  .nav-logo-img { height: 34px; }

  /* Hero section */
  .hero { padding: 80px 20px 40px; }
  .hero h1 { font-size: clamp(28px, 7vw, 48px); }
  .hero-cards { display: none; }

  /* Numbers grid */
  .numbers-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 16px; }
  .number-big { font-size: 36px; }

  /* Dashboard sidebar handled by dashboard-polish.css */
  .dash-nav-icon { font-size: 20px; margin-bottom: 2px; }
  .dash-nav-item span:not(.dash-nav-icon) { font-size: 10px; }
  .dash-main { padding: 16px; }
  .dash-section { padding: 0; }

  /* Messages layout */
  #msgPanelOrgs,
  #msgPanelAthletes > div {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }
  #convList, #athleteConvList {
    max-height: 200px;
  }
  #chatMessages, #athleteChatMessages {
    min-height: 280px !important;
  }

  /* Cards */
  .opp-grid { grid-template-columns: 1fr !important; }
  .card { padding: 16px; border-radius: 12px; }
  
  /* Forms */
  .form-row { flex-direction: column; }
  
  /* Welcome banner */
  #welcomeBanner {
    flex-direction: column;
    padding: 20px;
    gap: 16px;
  }
  #welcomeBanner > div:last-child {
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
  }

  /* Onboarding */
  #onboardingChecklist { padding: 16px; }

  /* Tables — horizontal scroll */
  .data-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table { min-width: 600px; }

  /* Profile page */
  .profile-hero { padding: 100px 16px 24px; }
  .profile-name { font-size: 24px; }
  .profile-grid { grid-template-columns: 1fr; }

  /* Modal */
  .modal { max-width: calc(100vw - 32px) !important; margin: 16px; }
  .modal-body { max-height: 60vh; overflow-y: auto; }

  /* About page */
  .about-values { grid-template-columns: 1fr !important; }
  .pricing-grid { grid-template-columns: 1fr; }

  /* Hide some decorative elements */
  .about-quote { padding: 24px 20px; }
}

@media (max-width: 480px) {
  /* Extra small phones */
  .dash-nav-item { min-width: 52px; padding: 6px 8px; }
  .numbers-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .number-big { font-size: 28px; }
}

/* PWA standalone mode adjustments */
@media (display-mode: standalone) {
  nav#nav { padding-top: env(safe-area-inset-top); }
  .dash-sidebar { padding-top: env(safe-area-inset-top); }
}

/* ── Nav público mobile — usuario logueado ── */
@media (max-width: 768px) {
  /* Ocultar greeting y sign out — solo mostrar My Dashboard */
  .nav-greeting-public { display: none !important; }
  .nav-signout-public { display: none !important; }
  /* My Dashboard button — más compacto */
  #universalNavRight a[href*="dashboard"],
  .nav-right a[href*="dashboard"] {
    font-size: 12px !important;
    padding: 6px 10px !important;
  }
}

/* ═══════════════════════════════════════
   JOIN FORM — Mobile premium UX
   ═══════════════════════════════════════ */
@media (max-width: 768px) {
  .progress-step span { display: none; }
  .progress-dot { width: 28px !important; height: 28px !important; font-size: 11px !important; }
  .progress-line { min-width: 16px !important; margin: 0 4px !important; }
  .role-selector { display: flex !important; flex-direction: column !important; gap: 10px !important; }
  .role-card { padding: 14px 16px !important; border-radius: 14px !important; display: flex !important; align-items: center !important; gap: 14px !important; }
  .form-group { margin-bottom: 14px !important; }
  .form-input, .form-select, .form-textarea { font-size: 16px !important; padding: 12px 14px !important; border-radius: 12px !important; }
  .form-label { font-size: 13px !important; font-weight: 600 !important; }
  .form-row { flex-direction: column !important; gap: 0 !important; }
  .section-divider { margin: 20px 0 14px !important; font-size: 10px !important; }
  .btn.btn-ink.btn-full { padding: 14px !important; font-size: 15px !important; border-radius: 14px !important; }
}

/* ── PWA Install Banner ── */
#pwaInstallBanner {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  background: #fff; border-top: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 -4px 24px rgba(0,0,0,.1);
  padding: 16px 20px; padding-bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 9999; animation: pwaSlideUp .3s cubic-bezier(.22,1,.36,1);
}
@keyframes pwaSlideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
#pwaInstallBanner.visible { display: flex !important; }
.pwa-banner-inner { display: flex; align-items: center; gap: 14px; width: 100%; }
.pwa-banner-icon { width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg,#0c1929,#1a3a5c); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pwa-banner-text { flex: 1; min-width: 0; }
.pwa-banner-title { font-size: 14px; font-weight: 700; color: #0c0c14; }
.pwa-banner-sub { font-size: 12px; color: #6b7280; margin-top: 1px; }
.pwa-banner-install { background: #1a3a5c; color: #fff; border: none; border-radius: 10px; padding: 8px 16px; font-size: 13px; font-weight: 700; cursor: pointer; font-family: inherit; white-space: nowrap; }
.pwa-banner-dismiss { background: none; border: none; color: #9ca3af; font-size: 22px; cursor: pointer; padding: 4px; line-height: 1; }

/* ═══════════════════════════════════════════════
   NOBIRU — SCROLL RHYTHM + SECTION CONTRAST
   Breathing sections, visual pauses
   ═══════════════════════════════════════════════ */

/* Stats strip — más presencia */
.stats-strip {
  padding: 28px 0 !important;
  background: #f4f6f9 !important;
  border-bottom: 1px solid rgba(0,0,0,.06) !important;
}

/* Section padding — más aire */
.section {
  padding: 96px 0 !important;
}
.section.alt {
  background: #f7f9fc !important;
  padding: 96px 0 !important;
}

/* Section headers — más presencia */
.section-kicker {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  color: var(--blue) !important;
  margin-bottom: 14px !important;
}
.section h2 {
  font-size: clamp(32px, 4vw, 52px) !important;
  font-weight: 800 !important;
  letter-spacing: -.045em !important;
  line-height: 1.05 !important;
  color: #08080f !important;
}
.section p.sub {
  font-size: 17px !important;
  color: rgba(0,0,0,.5) !important;
  line-height: 1.65 !important;
  letter-spacing: -.01em !important;
  max-width: 580px !important;
  margin: 0 auto !important;
}

/* Cards — more depth */
.card {
  border-radius: 18px !important;
  border: 1px solid rgba(0,0,0,.055) !important;
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 8px 32px rgba(0,0,0,.06) !important;
  transition: box-shadow .22s ease, transform .22s ease !important;
  padding: 32px !important;
}
.card:hover {
  box-shadow:
    0 2px 4px rgba(0,0,0,.05),
    0 16px 48px rgba(0,0,0,.09) !important;
  transform: translateY(-3px) !important;
}

/* Promise / feature cards */
.promise-card, .feature-card {
  border-radius: 18px !important;
}

/* CTA section — more presence */
.cta-section {
  padding: 100px 0 !important;
}

/* Footer — more air */
footer {
  padding-top: 64px !important;
  padding-bottom: 48px !important;
}

/* Mobile refinements */
@media (max-width: 768px) {
  .section { padding: 72px 0 !important; }
  .section.alt { padding: 72px 0 !important; }
  .section h2 { font-size: clamp(28px, 8vw, 40px) !important; letter-spacing: -.04em !important; }
  .section p.sub { font-size: 15px !important; }
  .card { padding: 22px !important; border-radius: 16px !important; }
  .cta-section { padding: 72px 0 !important; }
}

/* ═══════════════════════════════════════════════════════
   NOBIRU PUBLIC SITE — 10/10 FINAL
   ═══════════════════════════════════════════════════════ */

/* ── Steps — more visual impact ── */
.step {
  border-radius: 20px !important;
  padding: 32px !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 6px 24px rgba(0,0,0,.05) !important;
  transition: box-shadow .22s, transform .22s !important;
}
.step:hover {
  box-shadow: 0 4px 8px rgba(0,0,0,.06), 0 16px 48px rgba(0,0,0,.09) !important;
  transform: translateY(-3px) !important;
}
.step .num {
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .2em !important;
  color: var(--blue) !important;
}
.step h3 {
  font-size: 20px !important;
  letter-spacing: -.04em !important;
  font-weight: 800 !important;
  margin-top: 10px !important;
  color: #08080f !important;
}
.step p {
  font-size: 14px !important;
  color: rgba(0,0,0,.48) !important;
  line-height: 1.65 !important;
  margin-top: 8px !important;
}

/* ── Quote section — signature moment ── */
.quote {
  text-align: center !important;
  padding: 56px 40px !important;
  border-radius: 28px !important;
  border: 1px solid rgba(11,18,32,.07) !important;
  box-shadow: 0 2px 4px rgba(0,0,0,.04), 0 12px 40px rgba(0,0,0,.07) !important;
  max-width: 820px !important;
  margin: 0 auto !important;
}
.quote strong {
  font-size: clamp(24px, 3.5vw, 38px) !important;
  font-weight: 800 !important;
  letter-spacing: -.04em !important;
  line-height: 1.1 !important;
  color: #08080f !important;
  display: block !important;
  margin-bottom: 20px !important;
}
.quote p {
  font-size: 16px !important;
  color: rgba(0,0,0,.48) !important;
  line-height: 1.7 !important;
  max-width: 600px !important;
  margin: 0 auto !important;
  letter-spacing: -.01em !important;
}

/* ── Signature section stats — dramatic numbers ── */
#sigStatAthletes, #sigStatCountries, #sigStatLangs {
  font-size: 64px !important;
  font-weight: 800 !important;
  letter-spacing: -.07em !important;
  line-height: 1 !important;
  color: #08080f !important;
}

/* ── CTA box — more premium ── */
.cta-box {
  border-radius: 20px !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  padding: 32px 36px !important;
  box-shadow: 0 2px 40px rgba(0,0,0,.15) inset !important;
}
.cta-box p {
  font-size: 17px !important;
  line-height: 1.65 !important;
  color: rgba(255,255,255,.78) !important;
  letter-spacing: -.01em !important;
}

/* ── Footer — more memorable ── */
.footer {
  padding: 48px 0 36px !important;
  border-top: 1px solid rgba(0,0,0,.08) !important;
}
.footer span[data-i18n="footer.tagline"] {
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -.02em !important;
  color: #374151 !important;
}
.footer a {
  font-size: 13px !important;
  transition: color .15s !important;
  font-weight: 500 !important;
}
.footer a:hover { color: #0b1220 !important; }

/* ── Live stats strip — more presence ── */
#statVerified, #statCountries, #statLangs {
  font-size: 36px !important;
  font-weight: 800 !important;
  letter-spacing: -.055em !important;
  color: #08080f !important;
}

/* ── Nav — perfect glass ── */
.nav {
  backdrop-filter: saturate(180%) blur(20px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(20px) !important;
}

/* ── Btn primary — more presence ── */
.btn.primary {
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  padding: 13px 28px !important;
  border-radius: 12px !important;
  box-shadow: 0 2px 12px rgba(26,58,92,.25) !important;
  transition: transform .12s ease, box-shadow .12s ease !important;
}
.btn.primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 20px rgba(26,58,92,.35) !important;
}
.btn.primary:active {
  transform: scale(.97) !important;
}

/* ── Mobile public ── */
@media (max-width: 768px) {
  .quote { padding: 36px 24px !important; border-radius: 20px !important; }
  .quote strong { font-size: 24px !important; }
  #sigStatAthletes, #sigStatCountries, #sigStatLangs {
    font-size: 40px !important;
  }
  .step { padding: 24px 20px !important; border-radius: 16px !important; }
  .cta-box { padding: 24px !important; border-radius: 16px !important; }
}

/* ── Footer mobile ── */
@media (max-width: 768px) {
  .footer { padding: 32px 0 24px !important; }
  .footer > .container > div:first-child {
    flex-direction: column !important;
    gap: 28px !important;
    align-items: flex-start !important;
  }
  .footer > .container > div:first-child > div:last-child {
    gap: 24px !important;
  }
}

/* ── Signature stats — responsive ── */
#sigStatAthletes, #sigStatCountries, #sigStatLangs {
  font-size: clamp(48px, 6vw, 80px) !important;
  font-weight: 800 !important;
  letter-spacing: -.07em !important;
  color: #08080f !important;
  line-height: 1 !important;
}

@media (max-width: 768px) {
  #sigStatAthletes, #sigStatCountries, #sigStatLangs {
    font-size: 44px !important;
  }
  /* Signature section mobile — stack vertical */
  #sigStatAthletes + div + div + div + div {
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════
   PUBLIC SITE — Mobile polish final
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Grid cards — stack with air */
  .grid-3, .grid-2 {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .card {
    padding: 26px 22px !important;
    border-radius: 18px !important;
  }
  .card h3 {
    font-size: 19px !important;
  }
  .card p {
    font-size: 14px !important;
    line-height: 1.65 !important;
  }

  /* Steps — full width with air */
  .steps {
    flex-direction: column !important;
    gap: 14px !important;
  }
  .step {
    min-width: unset !important;
    padding: 24px 20px !important;
  }

  /* Quote section — mobile */
  section[style*="background:#0b1220"] {
    padding: 80px 0 !important;
  }
  section[style*="background:#0b1220"] h2 {
    font-size: clamp(32px, 9vw, 48px) !important;
  }
  section[style*="background:#0b1220"] p {
    font-size: 16px !important;
  }

  /* Signature section stats — tighter */
  #sigStatAthletes, #sigStatCountries, #sigStatLangs {
    font-size: 44px !important;
  }

  /* Live stats strip — stack on mobile */
  .stats-strip > .container {
    gap: 24px !important;
  }

  /* CTA band */
  .cta-band { padding: 72px 0 !important; }
  .cta-box {
    flex-direction: column !important;
    gap: 20px !important;
    padding: 24px !important;
  }
  .cta-box .btn { width: 100% !important; text-align: center !important; }

  /* Light sections — less padding on mobile */
  section.light, section.soft {
    padding: 72px 0 !important;
  }

  /* h2.sec — more readable on mobile */
  h2.sec {
    font-size: clamp(28px, 8vw, 44px) !important;
  }
  p.sub {
    font-size: 16px !important;
  }
}

/* ── Footer grid — mobile ── */
@media (max-width: 768px) {
  footer > .container > div:first-child {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  footer > .container > div:first-child > div:last-child {
    gap: 32px !important;
  }
}

/* ── Footer 4-column grid — mobile ── */
@media (max-width: 768px) {
  footer > div:first-child {
    grid-template-columns: 1fr 1fr !important;
    gap: 32px 24px !important;
  }
  footer > div:first-child > div:first-child {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 480px) {
  footer > div:first-child {
    grid-template-columns: 1fr !important;
  }
}

/* ── Admin tables — compact ── */
.admin-table th, .admin-table td {
  font-size: 12px !important;
  padding: 10px 8px !important;
  white-space: nowrap;
}
.admin-table th {
  font-size: 10px !important;
  letter-spacing: .08em !important;
}
/* Sidebar nav items — más compactos */
.dash-nav-item {
  padding: 9px 12px !important;
  font-size: 13px !important;
  gap: 10px !important;
}
.dash-sidebar-brand {
  font-size: 18px !important;
}
.dash-sidebar-user {
  padding: 10px 12px !important;
}

/* ── Admin Overview stats — compact grid ── */
#overviewStats {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 16px !important;
}
#overviewStats .dash-stat {
  padding: 14px 16px !important;
  border-radius: 10px !important;
}
#overviewStats .dash-stat-num {
  font-size: 28px !important;
  line-height: 1.1 !important;
}
#overviewStats .dash-stat-label {
  font-size: 9px !important;
  margin-top: 2px !important;
}
/* Sidebar items más compactos */
.dash-nav-item {
  padding: 8px 10px !important;
  font-size: 12px !important;
  gap: 8px !important;
  border-radius: 8px !important;
}
.dash-nav-icon {
  font-size: 14px !important;
  width: 18px !important;
}
.dash-sidebar-brand {
  font-size: 16px !important;
  padding: 0 12px !important;
}
.dash-sidebar-section {
  padding: 4px 8px !important;
}
.dash-sidebar-label {
  font-size: 9px !important;
  padding: 0 6px !important;
}
.dash-sidebar-user {
  padding: 8px 10px !important;
}
/* Admin tables — todas más compactas */
.admin-table {
  font-size: 12px !important;
}
.admin-table th {
  font-size: 9px !important;
  padding: 8px 6px !important;
  white-space: nowrap !important;
}
.admin-table td {
  font-size: 11px !important;
  padding: 8px 6px !important;
}
