/* ============================================================
   VARIABLES & RESET
============================================================ */
:root {
  --bg-deep:#0e1435; --bg-night:#131a42; --bg-blue:#243074;
  --gold:#d4a857; --gold-bright:#f4d47c; --gold-soft:#e8c57a;
  --cream:#fbf4e1; --cream-dim:#c8bca8; --ink:#f0ebdb;
  --line:rgba(212,168,87,0.25); --line-soft:rgba(250,245,232,0.12);
  --sidebar-w: 260px; --account-content-w: 960px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{
  font-family:'Cormorant Garamond',serif;
  background:var(--bg-deep);
  color:var(--ink);min-height:100vh;
}
body{
  background:
    radial-gradient(ellipse at 20% 10%, rgba(60, 75, 160, 0.45), transparent 55%),
    radial-gradient(ellipse at 85% 80%, rgba(95, 70, 150, 0.35), transparent 50%),
    radial-gradient(ellipse at 50% 50%, #1c2663 0%, #0f1638 100%);
  position:relative;
}

/* ── BACKGROUND ANIMATIONS (homepage) ── */
#stars{position:fixed;inset:0;z-index:0;pointer-events:none}
#constellations{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.75}

/* ── AUTH ── */
#authScreen{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;}
.auth-card{
  position:relative;z-index:1;max-width:400px;width:100%;
  background:rgba(13,18,50,.97);border:1px solid var(--line);
  backdrop-filter:blur(16px);padding:52px 40px 44px;text-align:center;
  box-shadow:0 40px 100px rgba(0,0,0,.6);animation:fadeUp .7s ease both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.auth-mono{font-family:'Italiana',serif;font-size:52px;color:var(--gold-bright);letter-spacing:.1em;margin-bottom:4px}
.auth-sub{font-style:italic;color:var(--cream-dim);font-size:14px;margin-bottom:32px}
.auth-card label{display:block;text-align:left;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:8px;}
.auth-card input{width:100%;background:rgba(255,255,255,.06);border:none;border-bottom:1px solid var(--line);padding:11px 0;font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);outline:none;margin-bottom:20px;transition:border-color .3s;}
.auth-card input:focus{border-bottom-color:var(--gold);}
.auth-card input::placeholder{color:rgba(240,235,219,.3)}
.auth-btn{width:100%;padding:14px;margin-top:8px;background:var(--gold);border:none;color:var(--bg-deep);font-family:'Cinzel',serif;font-size:11px;letter-spacing:.32em;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.auth-btn:hover{background:var(--gold-bright);letter-spacing:.38em;}
.auth-btn:disabled{opacity:.5;cursor:not-allowed;letter-spacing:.32em;}
.auth-err{display:none;margin-bottom:16px;padding:10px 14px;background:rgba(139,26,26,.15);border:1px solid rgba(139,26,26,.4);color:#f87171;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;text-align:left;}
.auth-err.show{display:block}
.auth-note{margin-top:20px;font-style:italic;color:var(--cream-dim);font-size:13px;line-height:1.6}
.auth-back{display:inline-block;margin-top:16px;color:var(--gold);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;opacity:.7;transition:opacity .2s;}
.auth-back:hover{opacity:1;}

/* ── APP ── */
#app{display:none;min-height:100vh;position:relative;z-index:2;}
body.rsvp-modal-open #app::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:666;
  background:rgba(5,8,25,.62);
  backdrop-filter:blur(8px);
  pointer-events:none;
}

/* ── BURGER (mobile) ── */
#burgerBtn{display:none;position:fixed;top:18px;right:16px;z-index:200;background:rgba(13,18,50,.9);border:1px solid var(--line);color:var(--gold);width:42px;height:42px;font-size:18px;cursor:pointer;backdrop-filter:blur(10px);}

/* ── SIDEBAR ── */
#sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:150;background:rgba(9,13,40,.97);border-right:1px solid var(--line);backdrop-filter:blur(20px);display:flex;flex-direction:column;transition:transform .3s ease;overflow-y:auto;}
.sb-top{padding:36px 28px 24px;border-bottom:1px solid var(--line-soft)}
.sb-mono{font-family:'Italiana',serif;font-size:38px;color:var(--gold-bright);letter-spacing:.1em}
.sb-date{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);margin-top:4px}
.sb-user-profile{margin-top:14px;display:flex;align-items:center;gap:10px;min-width:0}
.sb-user-avatar{width:34px;height:34px;border-radius:50%;border:1px solid rgba(212,168,87,.5);background:rgba(212,168,87,.08);color:var(--gold-bright);display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:14px;overflow:hidden}
.sb-user-avatar.has-image{padding:2px;background:rgba(255,255,255,.04)}
.sb-user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.sb-user{font-style:italic;color:var(--cream-dim);font-size:14px;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis}
.sb-nav{flex:1;padding:20px 0}
.sb-nav a{display:flex;align-items:center;gap:12px;padding:13px 28px;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--cream-dim);cursor:pointer;text-decoration:none;border-left:2px solid transparent;transition:all .25s;}
.sb-nav a:hover{color:var(--ink);background:rgba(212,168,87,.06);border-left-color:rgba(212,168,87,.3)}
.sb-nav a.active{color:var(--gold-bright);background:rgba(212,168,87,.08);border-left-color:var(--gold)}
.sb-nav .nav-ico{width:16px;text-align:center;opacity:.7}
.sb-bottom{padding:20px 28px;border-top:1px solid var(--line-soft)}
.sb-admin-link{width:100%;background:rgba(212,168,87,.08);border:1px solid rgba(212,168,87,.35);color:var(--gold-bright);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.22em;text-transform:uppercase;padding:10px;cursor:pointer;transition:all .25s;margin-bottom:12px;}
.sb-admin-link:hover{border-color:var(--gold);background:rgba(212,168,87,.14);color:var(--gold);}
.sb-logout{width:100%;background:none;border:1px solid var(--line);color:var(--cream-dim);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;padding:10px;cursor:pointer;transition:all .25s;}
.sb-logout:hover{border-color:var(--gold);color:var(--gold);}

/* ── MAIN ── */
#mainContent{margin-left:var(--sidebar-w);min-height:100vh;}
.account-hero{max-width:var(--account-content-w);margin:0 auto;padding:clamp(30px,4vw,50px) clamp(28px,4vw,72px) 0;}
.account-hero .mission-edit-header{max-width:none;margin:0 0 34px;}
.mission-page .account-hero{display:none;}
.photo-challenge-page .account-hero{display:none;}
.heroes-page .pilot-report{display:none;}

/* ── PAGES ── */
.page{display:none;animation:fadeUp .4s ease both}
.page.active{display:block}
.page-inner{max-width:var(--account-content-w);margin:0 auto;padding:0 clamp(28px,4vw,72px) 80px;}
.page-header{margin-bottom:48px}
.page-header .pre{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.page-header .pre::after{content:'';flex:1;height:1px;background:var(--line);max-width:80px}
.page-title{font-family:'Italiana',serif;font-size:clamp(34px,3.5vw,48px);color:var(--cream);letter-spacing:.04em}

/* ── MISSION EDIT HEADER ── */
.mission-edit-header{max-width:860px;margin-bottom:50px;}
.mission-edit-kicker{font-family:'Cinzel',serif;font-size:8px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.mission-edit-kicker::before,.mission-edit-kicker::after{content:'';display:block;width:40px;height:1px;background:var(--line);}
.mission-edit-header h1{font-family:'Italiana',serif;font-size:clamp(48px,7vw,76px);font-weight:400;line-height:.98;color:var(--cream);letter-spacing:.01em;margin-bottom:34px;}
.mission-edit-header h1 em{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold-bright);font-weight:400;margin-left:.16em;white-space:nowrap;}
.pilot-report{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;border:1px solid rgba(212,168,87,.32);border-radius:8px;background:linear-gradient(90deg,rgba(24,31,78,.72),rgba(18,24,64,.58));box-shadow:0 16px 46px rgba(0,0,0,.16);padding:16px 22px;position:relative;overflow:hidden;}
.pilot-report::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(251,244,225,.4) 0 1px,transparent 1.5px);background-size:118px 72px;background-position:42px 10px;opacity:.14;pointer-events:none;}
.pilot-orb{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 35% 28%,#f7d87f,#c59537 72%);border:1px solid rgba(244,212,124,.55);box-shadow:0 0 0 5px rgba(212,168,87,.11),0 0 24px rgba(244,212,124,.16);font-family:'Italiana',serif;font-size:27px;color:#17120a;position:relative;z-index:1;}
.pilot-orb.has-image{padding:4px;background:rgba(255,255,255,.06);overflow:hidden;}
.pilot-orb img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;}
.pilot-report-main{position:relative;z-index:1;min-width:0;}
.pilot-report-kicker{font-family:'Cinzel',serif;font-size:7px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.pilot-report-name{font-family:'Cormorant Garamond',serif;font-size:25px;line-height:1;color:var(--cream);}
.pilot-report-meta{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:9px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;color:var(--cream);text-transform:none;}
.pilot-report-meta strong{font-weight:400;color:var(--cream);}
.pilot-status-dot{width:8px;height:8px;border-radius:50%;background:#75c99a;box-shadow:0 0 8px rgba(117,201,154,.48);margin-right:2px;flex:0 0 auto;}
.pilot-countdown{position:relative;z-index:1;border-left:1px solid rgba(251,244,225,.16);padding-left:26px;text-align:center;min-width:112px;}
.pilot-countdown span,.pilot-countdown small{display:block;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.4em;text-transform:uppercase;color:var(--cream-dim);}
.pilot-countdown strong{display:block;margin:5px 0 1px;font-family:'Italiana',serif;font-size:30px;line-height:1;color:var(--gold-bright);font-weight:400;}

/* ── ACCUEIL — COUNTDOWN ── */
.homepage-phase-pill{display:inline-flex;align-items:center;justify-content:center;margin:8px auto 6px;padding:8px 16px;border:1px solid rgba(212,168,87,.42);border-radius:999px;background:rgba(212,168,87,.06);color:var(--gold);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.26em;text-transform:uppercase;box-shadow:0 10px 24px rgba(0,0,0,.08);}
.countdown-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0 8px;text-align:center;}
.countdown-box{display:inline-flex;align-items:flex-end;gap:6px;padding:20px 44px;background:rgba(212,168,87,.06);border:1px solid var(--line);margin:16px 0;}
.countdown-num{font-family:'Italiana',serif;font-size:78px;line-height:1;color:var(--gold-bright);letter-spacing:-.02em;}
.countdown-unit{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim);padding-bottom:14px;}
.countdown-label{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--cream-dim);margin-bottom:4px;}
.countdown-date{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);}
.welcome-msg{max-width:520px;margin:18px auto 0;font-size:19px;line-height:1.55;color:var(--cream-dim);font-style:italic;text-align:center;}
.secret-recall{margin-top:28px;display:inline-flex;align-items:center;gap:14px;max-width:520px;text-align:left;background:rgba(212,168,87,.08);border:1px solid rgba(212,168,87,.35);color:var(--cream);padding:15px 18px;cursor:pointer;transition:all .25s;}
.secret-recall:hover{border-color:var(--gold);background:rgba(212,168,87,.13);transform:translateY(-1px);}
.secret-recall-star{width:34px;height:34px;border-radius:50%;border:1px solid rgba(212,168,87,.55);display:flex;align-items:center;justify-content:center;color:var(--gold-bright);flex-shrink:0;}
.secret-recall-title{display:block;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-bright);}
.secret-recall-sub{display:block;margin-top:5px;font-style:italic;font-size:15px;color:var(--cream-dim);}
.secret-recall-modal{position:fixed;inset:0;z-index:620;display:none;align-items:center;justify-content:center;background:rgba(5,8,25,.88);backdrop-filter:blur(8px);padding:24px;overflow-y:auto;}
.secret-recall-modal.open{display:flex}
.secret-recall-card{width:100%;max-width:860px;background:linear-gradient(180deg,rgba(13,18,50,.98),rgba(8,12,36,.98));border:1px solid var(--line);box-shadow:0 36px 80px rgba(0,0,0,.65);padding:38px 34px 40px;position:relative;}
.secret-recall-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:1px solid var(--gold);background:transparent;color:var(--gold-bright);cursor:pointer;}
.secret-recall-eyebrow{text-align:center;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.secret-recall-card h3{text-align:center;font-family:'Italiana',serif;font-size:34px;font-weight:400;color:var(--cream);margin-bottom:6px;}
.secret-recall-card p{text-align:center;font-style:italic;color:var(--cream-dim);font-size:16px;margin-bottom:28px;}
.secret-recall-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;}
.secret-recall-item{border:1px solid rgba(212,168,87,.22);background:rgba(255,255,255,.035);overflow:hidden;}
.secret-recall-item img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;}
.secret-recall-caption{padding:12px 12px 14px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);}
.secret-recall-caption small{display:block;margin-top:5px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;letter-spacing:0;text-transform:none;color:var(--cream-dim);}
.secret-recall-item.locked{min-height:190px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--cream-dim);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.22em;text-transform:uppercase;opacity:.55;}
.secret-recall-home-link{grid-column:1/-1;justify-self:center;border:1px solid var(--gold);color:var(--gold-bright);text-decoration:none;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.24em;text-transform:uppercase;padding:14px 22px;background:rgba(212,168,87,.08);transition:all .25s;}
.secret-recall-home-link:hover{background:rgba(212,168,87,.16);transform:translateY(-1px);}
.welcome-journey-modal{position:fixed;inset:0;z-index:640;display:none;align-items:center;justify-content:center;background:rgba(5,8,25,.88);backdrop-filter:blur(9px);padding:24px;overflow-y:auto;}
.welcome-journey-modal.open{display:flex}
.welcome-journey-card{width:100%;max-width:620px;background:linear-gradient(180deg,rgba(18,25,70,.98),rgba(9,13,38,.98));border:1px solid rgba(212,168,87,.35);box-shadow:0 36px 90px rgba(0,0,0,.68);padding:42px 34px 34px;text-align:center;position:relative;animation:fadeUp .35s ease both;}
.welcome-journey-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:1px solid var(--gold);background:transparent;color:var(--gold-bright);cursor:pointer;}
.welcome-journey-avatar{width:118px;height:118px;margin:0 auto 20px;border-radius:50%;border:1px solid rgba(212,168,87,.65);background:radial-gradient(circle at 35% 25%,rgba(244,212,124,.28),rgba(255,255,255,.06));display:flex;align-items:center;justify-content:center;color:var(--gold-bright);font-size:34px;box-shadow:0 0 34px rgba(212,168,87,.18);overflow:hidden;}
.welcome-journey-avatar.has-image{padding:4px;background:rgba(255,255,255,.05);}
.welcome-journey-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;}
.welcome-journey-eyebrow{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.welcome-journey-card h3{font-family:'Italiana',serif;font-size:38px;font-weight:400;color:var(--cream);margin-bottom:14px;}
.welcome-journey-card p{max-width:500px;margin:0 auto 28px;color:var(--cream-dim);font-size:18px;line-height:1.7;font-style:italic;}
.welcome-journey-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;}
.welcome-journey-primary,.welcome-journey-secondary{border:1px solid var(--gold);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.24em;text-transform:uppercase;padding:13px 18px;text-decoration:none;cursor:pointer;}
.welcome-journey-primary{background:var(--gold);color:var(--bg-deep);}
.welcome-journey-secondary{background:transparent;color:var(--gold-bright);}
.welcome-journey-primary:hover,.welcome-journey-secondary:hover{transform:translateY(-1px);}

/* ── RSVP ── */
.edit-form{max-width:680px;background:radial-gradient(ellipse at top,rgba(255,255,255,.6),transparent 60%),linear-gradient(180deg,#fcfbf7,#f1efe8);border:1px solid rgba(212,168,87,.3);box-shadow:0 20px 60px rgba(0,0,0,.2);padding:40px;}
.edit-form .row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.edit-form .field{margin-bottom:20px}
.edit-form label{display:block;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:#8a6d2f;margin-bottom:8px;}
.edit-form input,.edit-form textarea{width:100%;background:rgba(255,255,255,.6);border:none;border-bottom:1px solid rgba(212,168,87,.5);padding:11px 0;font-family:'Cormorant Garamond',serif;font-size:18px;color:#0e1435;outline:none;transition:border-color .3s;}
.edit-form input:focus,.edit-form textarea:focus{border-bottom-color:#8a6d2f}
.edit-form input::placeholder,.edit-form textarea::placeholder{color:#9e8f76}
.edit-form textarea{resize:vertical;min-height:80px;padding:10px 0}
.edit-form input[type="number"]{-moz-appearance:textfield}
.edit-form input[type="number"]::-webkit-inner-spin-button{display:none}
.attendance-btns{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.att-btn{padding:12px;background:rgba(255,255,255,.6);border:1px solid rgba(212,168,87,.4);color:#5a4e38;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;cursor:pointer;transition:all .25s;}
.att-btn:hover{border-color:#8a6d2f;color:#8a6d2f}
.att-btn.active{background:rgba(212,168,87,.2);border-color:#8a6d2f;color:#5a3a00;font-weight:600}
.save-btn{padding:14px 40px;background:var(--gold);border:none;color:var(--bg-deep);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.32em;text-transform:uppercase;cursor:pointer;transition:all .3s;margin-top:8px;}
.save-btn:hover{background:var(--gold-bright);letter-spacing:.38em}
.save-btn:disabled{opacity:.5;cursor:not-allowed;letter-spacing:.32em}
#saveGroupBtn{display:block;margin:22px 0 0 auto;}
.form-msg{display:none;margin-top:16px;padding:12px 16px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;}
.form-msg.success{display:block;background:rgba(52,168,83,.1);border:1px solid rgba(52,168,83,.4);color:#166534}
.form-msg.error{display:block;background:rgba(139,26,26,.08);border:1px solid rgba(139,26,26,.3);color:#8b1a1a}

/* ── MODALE RÉPONSE ── */
.rsvp-edit-modal{position:fixed;inset:0;z-index:670;display:none;align-items:center;justify-content:center;background:rgba(5,8,25,.82);backdrop-filter:blur(8px);padding:24px;overflow-y:auto;}
.rsvp-edit-modal.open{display:flex}
body.rsvp-modal-open #rsvpEditModal{display:flex;z-index:2000;}
.rsvp-edit-card{position:relative;width:100%;max-width:760px;background:linear-gradient(180deg,rgba(18,25,70,.98),rgba(9,13,38,.98));border:1px solid rgba(212,168,87,.35);box-shadow:0 40px 100px rgba(0,0,0,.68);padding:38px;}
body.rsvp-modal-open .rsvp-edit-modal{
  background:transparent;
  backdrop-filter:none;
}
body.rsvp-modal-open .rsvp-edit-card{
  position:relative;
  z-index:2001;
}
.rsvp-edit-close{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;border:1px solid var(--gold);background:transparent;color:var(--gold-bright);cursor:pointer;}
.rsvp-edit-eyebrow{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:#9f7625;margin-bottom:8px;}
.rsvp-edit-title{font-family:'Italiana',serif;font-size:38px;color:var(--cream);margin-bottom:26px;}
.rsvp-edit-card .edit-form{max-width:none;background:transparent;border:none;box-shadow:none;padding:0;}
.rsvp-edit-card .edit-form label{color:var(--gold);}
.rsvp-edit-card .edit-form input,
.rsvp-edit-card .edit-form textarea{
  background:rgba(255,255,255,.07);
  border-bottom-color:rgba(212,168,87,.3);
  color:var(--ink);
}
.rsvp-edit-card .edit-form input:focus,
.rsvp-edit-card .edit-form textarea:focus{border-bottom-color:var(--gold);}
.rsvp-edit-card .edit-form input::placeholder,
.rsvp-edit-card .edit-form textarea::placeholder{color:rgba(240,235,219,.45);}
.rsvp-edit-card .att-btn{
  background:transparent;
  border-color:rgba(212,168,87,.3);
  color:var(--cream-dim);
}
.rsvp-edit-card .att-btn:hover{border-color:var(--gold);color:var(--gold-bright);}
.rsvp-edit-card .att-btn.active{background:rgba(212,168,87,.15);border-color:var(--gold);color:var(--gold-bright);}
.rsvp-edit-card .form-msg.success{color:#86efac;border-color:rgba(52,168,83,.35);background:rgba(52,168,83,.1);}
.rsvp-edit-card .form-msg.error{color:#fca5a5;border-color:rgba(139,26,26,.35);background:rgba(139,26,26,.1);}

.response-cta{width:100%;margin:44px 0 0;padding:28px 30px;background:linear-gradient(180deg,#fbf4e1,#efe1bb);border:1px solid rgba(138,109,47,.38);border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.2);display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;color:#16120c;position:relative;overflow:hidden;}
.response-cta::before,.response-cta::after{content:'✦';position:absolute;color:#9f7625;font-size:12px;}
.response-cta::before{top:14px;left:14px}.response-cta::after{right:14px;bottom:12px}
.response-cta-orb{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f2cf7a;border:1px solid #aa7d28;color:#16120c;font-size:24px;box-shadow:0 0 0 6px rgba(212,168,87,.12);}
.response-cta-kicker{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:#9f7625;margin-bottom:6px;}
.response-cta-title{font-family:'Italiana',serif;font-size:30px;color:#16120c;line-height:1;}
.response-cta-sub{margin-top:5px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:#6a5c40;}
.response-cta-btn{border:none;background:var(--gold);color:var(--bg-deep);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.3em;text-transform:uppercase;padding:14px 24px;cursor:pointer;transition:all .25s;white-space:nowrap;}
.response-cta-btn:hover{background:var(--gold-bright);transform:translateY(-1px);}

/* ── GROUPE ── */
.group-teaser{width:100%;margin-top:44px;padding:36px 48px 18px;background:linear-gradient(180deg,#fbf4e1,#f1e6c9);border:1px solid rgba(138,109,47,.35);border-bottom:none;border-radius:8px 8px 0 0;color:#16120c;}
.group-teaser-ornament{font-size:13px;color:#9f7625;letter-spacing:.4em;display:block;margin-bottom:18px;opacity:.85;}
.group-teaser-title{font-family:'Italiana',serif;font-size:34px;color:#16120c;margin-bottom:8px;letter-spacing:.02em;}
.group-teaser-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;color:#6a5c40;line-height:1.55;max-width:680px;margin:0;}
.group-teaser-sub em{font-style:normal;color:#8a6d2f}
.group-section{width:100%;background:linear-gradient(180deg,#f1e6c9,#efe1bb);border:1px solid rgba(138,109,47,.35);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 24px 70px rgba(0,0,0,.24);padding:22px 48px 42px;overflow:hidden;}
.group-member{display:grid;grid-template-columns:52px 1fr;gap:22px;align-items:center;background:rgba(255,253,246,.78);border:1px solid rgba(212,168,87,.2);border-radius:8px;margin-bottom:16px;padding:16px 18px;}
.group-member-header{display:flex;align-items:center;justify-content:center;min-width:0;}
.group-member-header.child-header{background:transparent;border-bottom:none;}
.group-member-badge{width:42px;height:42px;flex:0 0 42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f2cf7a;border:1px solid #aa7d28;color:#16120c;font-family:'Italiana',serif;font-size:20px;letter-spacing:0;text-transform:uppercase;box-shadow:0 0 0 6px rgba(212,168,87,.12);overflow:hidden;}
.group-member-badge.child{background:#f8df9f;color:#16120c}
.group-member-badge.has-image{padding:2px;background:rgba(255,255,255,.86);overflow:hidden;}
.group-member-badge img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;}
.group-member-name{display:none;}
.group-member-body{padding:0;background:transparent}
.group-member .gm-row{display:grid;grid-template-columns:minmax(120px,1fr) minmax(120px,1fr) minmax(120px,.8fr);gap:18px;align-items:end;margin-bottom:12px}
.group-member .gm-field{margin-bottom:0}
.group-member label{display:block;font-family:'Cinzel',serif;font-size:8px;letter-spacing:.28em;text-transform:uppercase;color:#9f7625;margin-bottom:7px;}
.group-member input{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(138,109,47,.28);padding:8px 0;font-family:'Cormorant Garamond',serif;font-size:17px;color:#16120c;outline:none;transition:border-color .3s;}
.group-member input:focus{border-bottom-color:#8a6d2f}
.group-member input::placeholder{color:#9e8f76}
.group-member .diet-field{margin-top:0}
.gm-type-value{border-bottom:1px solid rgba(138,109,47,.28);padding:8px 0;font-family:'Cormorant Garamond',serif;font-size:17px;color:#16120c;}

/* ── GÉNÉRATEUR D'ÉQUIPAGE ── */
.crew-generator{width:100%;margin-top:28px;border:1px solid rgba(212,168,87,.42);border-radius:8px;background:radial-gradient(circle at 50% 42%,rgba(36,48,116,.62),rgba(13,18,50,.94) 68%);padding:42px 48px 34px;box-shadow:0 30px 80px rgba(0,0,0,.32);position:relative;overflow:hidden;}
.crew-generator::before,.crew-generator::after{content:'✦';position:absolute;color:var(--gold-bright);font-size:13px;}
.crew-generator::before{top:18px;left:16px}.crew-generator::after{right:16px;bottom:14px}
.crew-generator-head{display:flex;align-items:flex-start;justify-content:center;gap:18px;margin-bottom:26px;text-align:center;}
.crew-generator-kicker{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.crew-generator-kicker::before,.crew-generator-kicker::after{content:'';display:inline-block;width:34px;height:1px;background:var(--line);vertical-align:middle;margin:0 14px;}
.crew-generator-title{font-family:'Italiana',serif;font-size:42px;color:var(--cream);letter-spacing:.02em;}
.crew-generator-count{display:none;}
.crew-generator canvas{display:block;width:100%;aspect-ratio:16/9;background:transparent;border:none;border-bottom:1px solid var(--line-soft);}
.crew-generator-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:16px;}
.crew-btn{border:1px solid var(--line);background:transparent;color:var(--gold-bright);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;padding:11px 16px;cursor:pointer;transition:all .25s;}
.crew-btn:hover{border-color:var(--gold);background:rgba(212,168,87,.08);}
.crew-btn.primary{background:var(--gold);border-color:var(--gold);color:var(--bg-deep);}
.crew-btn.primary:hover{background:var(--gold-bright);}

/* ── UPLOAD ── */
.upload-steps{width:100%;margin-bottom:32px}
.upload-step{background:rgba(255,255,255,.03);border:1px solid var(--line);padding:20px 24px;margin-bottom:12px;}
.upload-step-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.upload-step-num{width:28px;height:28px;border-radius:50%;background:var(--gold);color:var(--bg-deep);font-family:'Cinzel',serif;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.upload-step-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream);}
.folder-chips{display:flex;flex-wrap:wrap;gap:8px}
.folder-chip{padding:8px 18px;border:1px solid var(--line);background:transparent;color:var(--cream-dim);font-family:'Cormorant Garamond',serif;font-size:15px;cursor:pointer;transition:all .2s;letter-spacing:.04em;border-radius:2px;}
.folder-chip:hover{border-color:var(--gold);color:var(--gold)}
.folder-chip.active{border-color:var(--gold);background:rgba(212,168,87,.15);color:var(--gold-bright);font-weight:500;}
.upload-zone{border:2px dashed var(--line);padding:40px;text-align:center;cursor:pointer;transition:all .3s;opacity:.45;pointer-events:none;}
.upload-zone.ready{opacity:1;pointer-events:auto}
.upload-zone:hover,.upload-zone.drag{border-color:var(--gold);background:rgba(212,168,87,.05)}
.upload-ico{font-size:36px;margin-bottom:12px;opacity:.5}
.upload-text{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:6px}
.upload-sub{font-style:italic;color:var(--cream-dim);font-size:14px;opacity:.7}
#photoFileInput{display:none}
.upload-progress{margin-bottom:24px;display:none;width:100%}
.progress-bar-wrap{height:3px;background:var(--line);margin-top:8px}
.progress-bar{height:100%;background:var(--gold);width:0%;transition:width .3s}
.progress-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.2em;color:var(--cream-dim)}

/* ── GALERIE — SECTIONS D'ALBUMS ── */
.album-section{margin-bottom:52px}
.album-section:last-child{margin-bottom:0}
.album-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line);}
.album-icon{font-size:20px;opacity:.85;flex-shrink:0;}
.album-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);flex:1;}
.album-count{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:var(--cream-dim);opacity:.65;white-space:nowrap;}

/* ── GALERIE — GRILLE ── */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}
.photo-item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:rgba(255,255,255,.04)}
.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.photo-item:hover img{transform:scale(1.05)}
.photo-mine-badge{position:absolute;top:8px;left:8px;background:var(--gold);color:var(--bg-deep);font-family:'Cinzel',serif;font-size:7px;letter-spacing:.18em;text-transform:uppercase;padding:3px 7px;}
.photo-del{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.6);border:none;color:#fff;width:28px;height:28px;cursor:pointer;font-size:14px;display:none;align-items:center;justify-content:center;transition:background .2s;}
.photo-item:hover .photo-del{display:flex}
.photo-del:hover{background:rgba(139,26,26,.8)}
.photo-uploader{position:absolute;bottom:0;left:0;right:0;padding:6px 8px;background:rgba(0,0,0,.65);font-size:11px;color:rgba(255,255,255,.8);font-style:italic;transform:translateY(100%);transition:transform .3s;}
.photo-item:hover .photo-uploader{transform:translateY(0)}
.photo-empty{font-style:italic;color:var(--cream-dim);font-size:18px;text-align:center;padding:60px 0;opacity:.6;}

/* ── FICHE DE MISSION ── */
.mission-inner{max-width:var(--account-content-w)}
.mission-header{margin-bottom:22px}
.mission-header-kicker{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.mission-header-kicker::before,.mission-header-kicker::after{
  content:'';
  display:block;
  width:42px;
  height:1px;
  background:var(--line);
}
.mission-title{
  font-family:'Italiana',serif;
  font-size:clamp(46px,6.5vw,74px);
  font-weight:400;
  line-height:.96;
  color:var(--cream);
  letter-spacing:.02em;
}
.mission-title em{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--gold-bright);
  font-weight:400;
}
.mission-phase-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:16px;
  padding:8px 15px;
  border:1px solid rgba(212,168,87,.42);
  border-radius:999px;
  background:rgba(212,168,87,.07);
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.26em;
  text-transform:uppercase;
}
.mission-hero{
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  align-items:center;
  border:1px solid rgba(212,168,87,.28);
  background:linear-gradient(90deg,rgba(18,25,70,.9),rgba(11,16,46,.94));
  box-shadow:0 18px 54px rgba(0,0,0,.2);
  padding:18px;
}
.mission-hero-main{
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}
.mission-avatar{
  width:84px;
  height:84px;
  flex:0 0 auto;
  border-radius:50%;
  border:1px solid rgba(212,168,87,.7);
  background:radial-gradient(circle at 35% 28%,rgba(244,212,124,.3),rgba(255,255,255,.05));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:var(--gold-bright);
  font-size:30px;
  box-shadow:0 0 0 6px rgba(212,168,87,.09),0 0 28px rgba(244,212,124,.12);
}
.mission-avatar.has-image{padding:4px;background:rgba(255,255,255,.05)}
.mission-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.mission-hero-copy{min-width:0}
.mission-hero-kicker{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:5px;
}
.mission-hero-name{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;
  line-height:1;
  color:var(--cream);
}
.mission-hero-status{
  margin-top:6px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:16px;
}
.mission-hero-count{
  margin-top:8px;
  color:var(--cream);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.26em;
  text-transform:uppercase;
}
.mission-points-orb{
  min-width:126px;
  height:126px;
  border-radius:50%;
  border:1px solid rgba(244,212,124,.5);
  background:rgba(212,168,87,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  box-shadow:0 0 0 6px rgba(212,168,87,.08);
}
.mission-points-label{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
}
.mission-points-value{
  margin-top:6px;
  font-family:'Italiana',serif;
  font-size:46px;
  line-height:1;
  color:var(--gold-bright);
}
.mission-progress-card{
  margin-top:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:16px;
}
.mission-progress-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}
.mission-progress-title{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  color:var(--cream);
}
.mission-progress-percent{
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold);
  white-space:nowrap;
}
.mission-progress-track{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}
.mission-progress-fill{
  height:100%;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright));
}
.mission-progress-text{
  margin-top:10px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.45;
}
.mission-grid-section{margin-top:28px}
.mission-grid-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:12px;
  margin-bottom:12px;
}
.mission-grid-kicker{
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
}
.mission-grid-sub{
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
}
.mission-trophy-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
}
.mission-trophy-card{
  min-height:154px;
  border:1px solid var(--line-soft);
  padding:14px;
  background:rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.mission-trophy-card.is-unlocked{
  border-color:rgba(212,168,87,.42);
  background:linear-gradient(180deg,rgba(212,168,87,.09),rgba(18,25,70,.45));
}
.mission-trophy-card.is-locked{
  opacity:.68;
}
.mission-trophy-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
}
.mission-trophy-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid rgba(212,168,87,.28);
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gold-bright);
  font-size:18px;
}
.mission-trophy-icon.has-image{
  overflow:hidden;
  background:rgba(255,255,255,.06);
}
.mission-trophy-icon img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.mission-trophy-points{
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--cream);
}
.mission-trophy-label{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;
  line-height:1.05;
  color:var(--cream);
  margin-bottom:6px;
}
.mission-trophy-desc{
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
  line-height:1.45;
}
.mission-empty-state{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:22px;
}
.mission-empty-title{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  color:var(--cream);
  margin-bottom:6px;
}
.mission-empty-text{
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.5;
}

/* ── COIN DES HÉROS ── */
.heroes-inner{max-width:var(--account-content-w)}
.heroes-summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:20px;
  align-items:stretch;
  border:1px solid rgba(212,168,87,.28);
  background:linear-gradient(90deg,rgba(18,25,70,.9),rgba(11,16,46,.94));
  box-shadow:0 18px 54px rgba(0,0,0,.2);
  padding:24px;
}
.heroes-summary-copy{min-width:0}
.heroes-summary-kicker{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}
.heroes-summary-title{
  font-family:'Italiana',serif;
  font-size:clamp(38px,5vw,60px);
  font-weight:400;
  line-height:.96;
  color:var(--cream);
  letter-spacing:.02em;
  margin-bottom:12px;
}
.heroes-summary-text{
  max-width:760px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:17px;
  line-height:1.7;
}
.heroes-summary-orb{
  min-width:156px;
  height:156px;
  border-radius:50%;
  border:1px solid rgba(244,212,124,.5);
  background:rgba(212,168,87,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  box-shadow:0 0 0 6px rgba(212,168,87,.08);
  text-align:center;
  padding:20px;
}
.heroes-summary-orb span{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
}
.heroes-summary-orb strong{
  margin-top:6px;
  font-family:'Italiana',serif;
  font-size:48px;
  line-height:1;
  color:var(--gold-bright);
}
.heroes-summary-orb small{
  margin-top:8px;
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.heroes-phase-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:16px;
  padding:8px 15px;
  border:1px solid rgba(212,168,87,.42);
  border-radius:999px;
  background:rgba(212,168,87,.07);
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.26em;
  text-transform:uppercase;
}
.heroes-shared-hint{
  margin-top:14px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.5;
}
.heroes-grid{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:14px;
}
.heroes-card{
  border:1px solid rgba(212,168,87,.2);
  background:linear-gradient(180deg,rgba(18,25,70,.88),rgba(11,16,46,.96));
  padding:18px;
  box-shadow:0 16px 44px rgba(0,0,0,.16);
}
.heroes-card-top{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.heroes-card-avatar{
  width:72px;
  height:72px;
  flex:0 0 auto;
  border-radius:50%;
  border:1px solid rgba(212,168,87,.7);
  background:radial-gradient(circle at 35% 28%,rgba(244,212,124,.3),rgba(255,255,255,.05));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:var(--gold-bright);
  font-size:26px;
  box-shadow:0 0 0 5px rgba(212,168,87,.09),0 0 24px rgba(244,212,124,.12);
}
.heroes-card-avatar.has-image{padding:4px;background:rgba(255,255,255,.05)}
.heroes-card-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.heroes-card-copy{min-width:0}
.heroes-card-kicker{
  font-family:'Cinzel',serif;
  font-size:7px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:5px;
}
.heroes-card-name{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1;
  color:var(--cream);
}
.heroes-card-meta{
  margin-top:6px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
}
.heroes-card-footer{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.heroes-card-role{
  min-width:0;
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
  line-height:1.45;
}
.heroes-card-points{
  min-width:96px;
  text-align:right;
}
.heroes-card-points span{
  display:block;
  font-family:'Cinzel',serif;
  font-size:7px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:4px;
}
.heroes-card-points strong{
  font-family:'Italiana',serif;
  font-size:28px;
  line-height:1;
  color:var(--gold-bright);
}
.heroes-empty-state{
  grid-column:1/-1;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:22px;
}
.heroes-empty-title{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  color:var(--cream);
  margin-bottom:6px;
}
.heroes-empty-text{
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.5;
}

/* ── DÉFI PHOTO ── */
.photo-challenge-inner{display:flex;flex-direction:column;gap:18px;}
.photo-challenge-header{
  border:1px solid var(--line);
  background:rgba(11,21,78,.88);
  padding:24px;
}
.photo-challenge-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.photo-challenge-title{
  margin:0;
  color:var(--cream);
  font-family:'Italiana',serif;
  font-size:clamp(34px,5vw,62px);
  line-height:.95;
}
.photo-challenge-title em{
  color:var(--gold-bright);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
}
.photo-challenge-text{
  margin:12px 0 0;
  max-width:780px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:18px;
  line-height:1.6;
}
.photo-challenge-summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:stretch;
  border:1px solid rgba(212,168,87,.28);
  background:linear-gradient(90deg,rgba(18,25,70,.9),rgba(11,16,46,.94));
  box-shadow:0 18px 54px rgba(0,0,0,.2);
  padding:22px;
}
.photo-challenge-summary-copy{min-width:0}
.photo-challenge-summary-kicker{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}
.photo-challenge-summary-title{
  font-family:'Italiana',serif;
  font-size:clamp(38px,5vw,60px);
  font-weight:400;
  line-height:.96;
  color:var(--cream);
  letter-spacing:.02em;
  margin-bottom:12px;
}
.photo-challenge-summary-text{
  max-width:760px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:17px;
  line-height:1.7;
}
.photo-challenge-summary-orb{
  min-width:156px;
  height:156px;
  border-radius:50%;
  border:1px solid rgba(244,212,124,.5);
  background:rgba(212,168,87,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  box-shadow:0 0 0 6px rgba(212,168,87,.08);
  text-align:center;
  padding:20px;
}
.photo-challenge-summary-orb span{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
}
.photo-challenge-summary-orb strong{
  margin-top:6px;
  font-family:'Italiana',serif;
  font-size:48px;
  line-height:1;
  color:var(--gold-bright);
}
.photo-challenge-summary-orb small{
  margin-top:8px;
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.photo-challenge-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.photo-challenge-meta-chip{
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:14px 16px;
}
.photo-challenge-meta-label{
  display:block;
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}
.photo-challenge-meta-chip strong{
  display:block;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  line-height:1;
}
.photo-challenge-section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
}
.photo-challenge-section-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.photo-challenge-section-sub{
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
  margin-top:4px;
  line-height:1.5;
}
.photo-challenge-refresh{
  width:40px;
  height:40px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--gold-bright);
  font-family:'Cinzel',serif;
  font-size:16px;
  cursor:pointer;
}
.photo-challenge-refresh:hover{border-color:var(--gold);background:rgba(212,168,87,.08);}
.photo-challenge-message{
  display:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:14px 16px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.5;
}
.photo-challenge-message.show{
  display:block;
}
.photo-challenge-message.success{
  border-color:rgba(52,168,83,.35);
  background:rgba(52,168,83,.1);
  color:#c4f0cf;
}
.photo-challenge-message.error{
  border-color:rgba(139,26,26,.3);
  background:rgba(139,26,26,.1);
  color:#f9c4c4;
}
.photo-challenge-loading{
  display:none;
  padding:24px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--cream-dim);
  font-style:italic;
  font-size:16px;
}
.photo-challenge-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:14px;
}
.photo-challenge-card{
  border:1px solid rgba(212,168,87,.2);
  background:linear-gradient(180deg,rgba(18,25,70,.88),rgba(11,16,46,.96));
  padding:16px;
  box-shadow:0 16px 44px rgba(0,0,0,.16);
  display:flex;
  flex-direction:column;
  gap:14px;
  cursor:pointer;
  text-align:left;
}
.photo-challenge-card:hover{
  border-color:rgba(212,168,87,.42);
  transform:translateY(-1px);
}
.photo-challenge-card.is-completed{
  border-color:rgba(212,168,87,.52);
  background:linear-gradient(180deg,rgba(212,168,87,.09),rgba(18,25,70,.45));
}
.photo-challenge-card.is-hidden .photo-challenge-card-title{
  letter-spacing:.02em;
}
.photo-challenge-cover{
  border:1px solid rgba(212,168,87,.18);
  background:rgba(255,255,255,.03);
  aspect-ratio:16/9;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gold-bright);
  font-size:28px;
}
.photo-challenge-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-challenge-card-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.photo-challenge-card-title{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1.02;
  color:var(--cream);
}
.photo-challenge-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.photo-challenge-chip{
  padding:4px 8px;
  border:1px solid rgba(212,168,87,.25);
  border-radius:999px;
  font-family:'Cinzel',serif;
  font-size:7px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--cream);
  white-space:nowrap;
}
.photo-challenge-chip.is-bonus{color:var(--gold-bright);border-color:rgba(244,212,124,.4);}
.photo-challenge-chip.is-secret{color:#d7c9a8;border-color:rgba(255,255,255,.18);}
.photo-challenge-chip.is-points{color:var(--gold-bright);border-color:rgba(244,212,124,.4);}
.photo-challenge-card-desc{
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.55;
}
.photo-challenge-card-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
}
.photo-challenge-card-state{
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}
.photo-challenge-card-action{
  font-style:italic;
  font-size:15px;
  color:var(--cream);
}
.photo-challenge-empty{
  grid-column:1/-1;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:22px;
}
.photo-challenge-empty-title{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  color:var(--cream);
  margin-bottom:6px;
}
.photo-challenge-empty-text{
  color:var(--cream-dim);
  font-style:italic;
  font-size:15px;
  line-height:1.5;
}
.photo-challenge-modal{
  position:fixed;
  inset:0;
  z-index:680;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(5,8,25,.82);
  backdrop-filter:blur(8px);
  padding:24px;
  overflow-y:auto;
}
.photo-challenge-modal.open{display:flex}
.photo-challenge-card-modal{
  position:relative;
  width:100%;
  max-width:1040px;
  background:linear-gradient(180deg,rgba(18,25,70,.98),rgba(9,13,38,.98));
  border:1px solid rgba(212,168,87,.35);
  box-shadow:0 40px 100px rgba(0,0,0,.68);
  padding:34px;
  border-radius:28px;
}
.photo-challenge-close{
  position:absolute;
  top:16px;
  right:16px;
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid var(--gold);
  background:transparent;
  color:var(--gold-bright);
  cursor:pointer;
}
.photo-challenge-modal-head{
  margin-bottom:18px;
}
.photo-challenge-modal-cover{
  height:100%;
  border:1px solid rgba(212,168,87,.18);
  background:radial-gradient(circle at top,rgba(255,255,255,.12),rgba(255,255,255,.03));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-radius:24px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}
.photo-challenge-modal-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-challenge-modal-visual{
  position:relative;
  min-height:clamp(260px, 46vh, 360px);
  margin-bottom:22px;
}
.photo-challenge-modal-overlay{
  position:absolute;
  left:20px;
  right:20px;
  bottom:20px;
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-end;
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(7,10,29,.1),rgba(7,10,29,.82));
}
.photo-challenge-modal-status,
.photo-challenge-modal-latest{
  color:var(--cream);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.photo-challenge-modal-latest{
  color:rgba(240,235,219,.78);
  text-align:right;
}
.photo-challenge-modal-copy{
  border:1px solid rgba(212,168,87,.14);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  padding:24px 24px 22px;
  display:flex;
  flex-direction:column;
  border-radius:24px;
}
.photo-challenge-modal-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.34em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.photo-challenge-modal-title{
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:50px;
  line-height:.95;
  margin-bottom:12px;
}
.photo-challenge-modal-desc{
  color:var(--cream-dim);
  font-size:18px;
  line-height:1.65;
}
.photo-challenge-modal-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:18px 0 22px;
}
.photo-challenge-modal-chip{
  padding:7px 10px;
  border:1px solid rgba(212,168,87,.25);
  border-radius:999px;
  color:var(--gold-bright);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.photo-challenge-modal-aside{
  margin-top:4px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(212,168,87,.12);
  background:rgba(4,8,26,.28);
  color:rgba(240,235,219,.78);
  font-size:15px;
  line-height:1.55;
}
.photo-challenge-upload{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);
  gap:18px;
  align-items:start;
}
.photo-challenge-upload-card,
.photo-challenge-comment-card{
  border:1px solid rgba(212,168,87,.14);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.035));
  padding:22px;
  border-radius:22px;
}
.photo-challenge-upload-card.is-disabled{
  opacity:.88;
}
.photo-challenge-upload-head{
  display:flex;
  gap:16px;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:16px;
}
.photo-challenge-upload-title{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.photo-challenge-upload-note{
  color:var(--cream-dim);
  font-size:15px;
  line-height:1.55;
  max-width:52ch;
}
.photo-challenge-upload-state{
  flex-shrink:0;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(212,168,87,.2);
  color:var(--gold-bright);
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.photo-challenge-selected-preview{
  margin-bottom:16px;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(212,168,87,.14);
  background:rgba(0,0,0,.2);
  aspect-ratio:16/9;
}
.photo-challenge-selected-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-challenge-file-name{
  color:var(--cream);
  font-size:16px;
  line-height:1.5;
  margin-bottom:14px;
}
.photo-challenge-btn-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.photo-challenge-btn-row[hidden],
.photo-challenge-resubmit-gate[hidden],
.photo-challenge-confirm[hidden]{
  display:none !important;
}
.photo-challenge-btn{
  border:1px solid var(--gold);
  background:var(--gold);
  color:var(--bg-deep);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.24em;
  text-transform:uppercase;
  padding:12px 16px;
  cursor:pointer;
}
.photo-challenge-btn.secondary{
  background:transparent;
  color:var(--gold-bright);
  border-color:var(--line);
}
.photo-challenge-btn:disabled{
  opacity:.5;
  cursor:not-allowed;
}
.photo-challenge-btn-wide{
  width:100%;
}
.photo-challenge-resubmit-gate{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.photo-challenge-resubmit-copy{
  color:var(--cream-dim);
  font-size:15px;
  line-height:1.55;
}
.photo-challenge-comment-card label{
  display:block;
  font-family:'Cinzel',serif;
  font-size:8px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}
.photo-challenge-comment-note{
  color:rgba(240,235,219,.68);
  font-size:14px;
  line-height:1.5;
  margin-bottom:12px;
}
.photo-challenge-comment-card textarea{
  width:100%;
  min-height:220px;
  resize:vertical;
  border:1px solid rgba(212,168,87,.2);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  font-family:'Cormorant Garamond',serif;
  font-size:18px;
  padding:14px 12px;
  outline:none;
}
.photo-challenge-comment-card textarea:disabled{
  opacity:.7;
  cursor:not-allowed;
}
.photo-challenge-comment-card textarea::placeholder{color:rgba(240,235,219,.45);}
.photo-challenge-modal-message{
  margin-top:14px;
  color:var(--cream-dim);
  font-size:15px;
  line-height:1.5;
}
.photo-challenge-confirm{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(4,6,20,.74);
}
.photo-challenge-confirm-card{
  width:min(100%,420px);
  border:1px solid rgba(212,168,87,.35);
  background:linear-gradient(180deg,rgba(18,25,70,.98),rgba(9,13,38,.98));
  box-shadow:0 32px 80px rgba(0,0,0,.45);
  padding:22px;
}
.photo-challenge-confirm-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.34em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.photo-challenge-confirm-title{
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:30px;
  line-height:1;
}
.photo-challenge-confirm-actions{
  display:flex;
  gap:10px;
  margin-top:18px;
}
.photo-challenge-confirm-actions .photo-challenge-btn{
  flex:1;
}

.onboarding-inner{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.onboarding-hero{
  border:1px solid var(--line);
  background:rgba(11,21,78,.88);
  padding:24px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 180px;
  gap:16px;
  align-items:stretch;
}
.onboarding-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.onboarding-title{
  margin:0;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(34px,5vw,62px);
  line-height:.95;
}
.onboarding-body{
  margin:12px 0 0;
  max-width:760px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:18px;
  line-height:1.6;
}
.onboarding-orb{
  border:1px solid rgba(212,168,87,.48);
  background:rgba(212,168,87,.08);
  min-height:180px;
  padding:20px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
}
.onboarding-orb span{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.onboarding-orb strong{
  margin-top:10px;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1;
}
.onboarding-orb small{
  margin-top:8px;
  color:var(--cream-dim);
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  line-height:1.4;
}
.onboarding-section{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.onboarding-section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
}
.onboarding-section-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.onboarding-section-sub{
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
}
.onboarding-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.onboarding-step-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:18px;
}
.onboarding-step-num{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.onboarding-step-title{
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:26px;
  line-height:1;
  margin-bottom:10px;
}
.onboarding-step-body{
  color:var(--cream-dim);
  font-size:16px;
  line-height:1.5;
  font-style:italic;
}
.onboarding-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.onboarding-btn{
  min-height:46px;
  padding:0 16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--cream);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
}
.onboarding-btn.primary{
  background:var(--gold);
  color:var(--bg-deep);
  border-color:var(--gold);
}
.onboarding-btn.secondary{
  border-color:rgba(212,168,87,.5);
}

.time-machine-inner{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.time-machine-hero{
  border:1px solid var(--line);
  background:rgba(11,21,78,.88);
  padding:24px;
}
.time-machine-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.time-machine-title{
  margin:0;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(34px,5vw,62px);
  line-height:.95;
}
.time-machine-text{
  margin:12px 0 0;
  max-width:760px;
  color:var(--cream-dim);
  font-style:italic;
  font-size:18px;
  line-height:1.6;
}
.time-machine-orbital{
  display:grid;
  grid-template-columns:minmax(0,220px) minmax(0,1fr);
  gap:16px;
  align-items:stretch;
}
.time-machine-orb,
.time-machine-orb-text,
.time-machine-phase-card,
.time-machine-portal-card,
.time-machine-empty{
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}
.time-machine-orb{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:180px;
  padding:20px;
  text-align:center;
}
.time-machine-orb span{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.time-machine-orb strong{
  display:block;
  margin-top:10px;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1;
}
.time-machine-orb small{
  display:block;
  margin-top:8px;
  color:var(--cream-dim);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.time-machine-orb-text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:20px 22px;
}
.time-machine-orb-text strong{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.time-machine-orb-text span{
  color:var(--cream);
  font-size:18px;
  line-height:1.6;
}
.time-machine-section{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.time-machine-section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
}
.time-machine-section-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.time-machine-section-sub{
  color:var(--cream-dim);
  font-style:italic;
  font-size:14px;
}
.time-machine-phase-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.time-machine-phase-card{
  padding:18px;
}
.time-machine-phase-card.is-active{
  border-color:rgba(212,168,87,.65);
  background:rgba(212,168,87,.08);
}
.time-machine-phase-card-kicker{
  color:var(--gold);
  font-family:'Cinzel',serif;
  font-size:9px;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.time-machine-phase-card-title{
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  line-height:1;
  margin-bottom:10px;
}
.time-machine-phase-card-text{
  color:var(--cream-dim);
  font-size:16px;
  line-height:1.5;
  font-style:italic;
}
.time-machine-portal-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.time-machine-portal-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:108px;
  padding:16px;
  text-align:left;
  cursor:pointer;
}
.time-machine-portal-icon{
  color:var(--gold);
  font-size:18px;
  line-height:1;
}
.time-machine-portal-label{
  color:var(--cream);
  font-family:'Cinzel',serif;
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.time-machine-empty{
  padding:20px;
}
.time-machine-empty-title{
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  margin-bottom:8px;
}
.time-machine-empty-text{
  color:var(--cream-dim);
  font-size:16px;
  font-style:italic;
  line-height:1.5;
}

/* ── MODALE UPLOAD ── */
.upload-modal{position:fixed;inset:0;z-index:600;background:rgba(5,8,25,.85);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px;}
.upload-modal.open{display:flex}
.upload-modal-card{background:rgba(13,18,50,.98);border:1px solid var(--line);width:100%;max-width:480px;padding:36px 32px 28px;animation:fadeUp .35s ease both;}
.upload-modal-title{font-family:'Italiana',serif;font-size:30px;color:var(--cream);letter-spacing:.04em;margin-bottom:20px;}
.upload-modal-summary{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:16px;}
.upload-modal-logs{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;margin-bottom:24px;}
.upload-log-row{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border:1px solid var(--line-soft);font-size:14px;}
.upload-log-row.ok{border-color:rgba(100,200,120,.3);background:rgba(100,200,120,.06);}
.upload-log-row.err{border-color:rgba(220,100,100,.3);background:rgba(220,100,100,.06);}
.upload-log-row.skip{border-color:var(--line-soft);opacity:.55;}
.upload-log-ico{font-size:15px;flex-shrink:0;margin-top:1px;}
.upload-log-name{color:var(--ink);flex:1;word-break:break-all;}
.upload-log-detail{font-style:italic;color:var(--cream-dim);font-size:12px;}
.upload-modal-close{width:100%;padding:11px;background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s;}
.upload-modal-close:hover{background:var(--gold);color:var(--bg-deep);}

/* ── LIGHTBOX ── */
#lightbox{position:fixed;inset:0;z-index:500;background:rgba(5,8,25,.95);display:none;align-items:center;justify-content:center;}
#lightbox.open{display:flex}
#lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}
#lightbox .lb-close{position:absolute;top:20px;right:20px;background:none;border:1px solid var(--line);color:var(--gold);width:40px;height:40px;font-size:20px;cursor:pointer;}

/* ── INFOS ── */
.infos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;width:100%}
.info-card{background:rgba(255,255,255,.025);border:1px solid rgba(212,168,87,.18);padding:22px 24px;transition:border-color .25s,background .25s;}
.info-card:hover{background:rgba(255,255,255,.035);border-color:rgba(212,168,87,.38)}
.info-card-ico{font-size:20px;margin-bottom:10px;opacity:.72}
.info-card-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:9px;}
.info-card p{font-size:15px;line-height:1.58;color:var(--cream-dim);font-style:italic}
.info-card a{color:var(--gold);text-decoration:none;border-bottom:1px solid var(--line)}
.info-card a:hover{border-bottom-color:var(--gold)}

/* ── MODAL CHOIX ADMIN ── */
#adminChoiceModal{display:none;position:fixed;inset:0;z-index:300;background:rgba(5,8,25,.85);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:20px;}
#adminChoiceModal.open{display:flex}
.admin-choice-card{max-width:440px;width:100%;background:rgba(13,18,50,.98);border:1px solid var(--line);padding:48px 40px;text-align:center;box-shadow:0 40px 100px rgba(0,0,0,.7);animation:fadeUp .5s ease both;}
.admin-choice-mono{font-family:'Italiana',serif;font-size:42px;color:var(--gold-bright);letter-spacing:.1em;margin-bottom:4px}
.admin-choice-sub{font-style:italic;color:var(--cream-dim);font-size:14px;margin-bottom:36px}
.admin-choice-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:block;}
.admin-choice-btns{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.admin-choice-btn{padding:16px 12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--cream);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:all .25s;}
.admin-choice-btn:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(212,168,87,.08)}
.admin-choice-btn .btn-ico{display:block;font-size:22px;margin-bottom:10px;opacity:.7}

/* ── OVERLAY SIDEBAR (mobile) ── */
#sidebarOverlay{display:none;position:fixed;inset:0;z-index:140;background:rgba(0,0,0,.5);}

/* ── PROFIL MODAL ── */
.sb-user-avatar{transition:border-color .2s,box-shadow .2s;}
.sb-user-profile:hover .sb-user-avatar{border-color:var(--gold);box-shadow:0 0 0 4px rgba(212,168,87,.18);}
.sb-user-profile:hover .sb-user{color:var(--gold-soft);}
.profile-modal{position:fixed;inset:0;z-index:660;display:none;align-items:center;justify-content:center;background:rgba(5,8,25,.88);backdrop-filter:blur(9px);padding:24px;overflow-y:auto;}
.profile-modal.open{display:flex}
.profile-card{width:100%;max-width:480px;background:linear-gradient(180deg,rgba(18,25,70,.98),rgba(9,13,38,.98));border:1px solid rgba(212,168,87,.35);box-shadow:0 36px 90px rgba(0,0,0,.68);padding:42px 36px 36px;position:relative;animation:fadeUp .35s ease both;}
.profile-card-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:1px solid var(--gold);background:transparent;color:var(--gold-bright);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;}
.profile-avatar-wrap{display:flex;justify-content:center;margin-bottom:18px;}
.profile-avatar{width:90px;height:90px;border-radius:50%;border:1px solid rgba(212,168,87,.65);background:radial-gradient(circle at 35% 25%,rgba(244,212,124,.22),rgba(255,255,255,.06));display:flex;align-items:center;justify-content:center;color:var(--gold-bright);font-size:28px;overflow:hidden;}
.profile-avatar.has-image{padding:3px;background:rgba(255,255,255,.05);}
.profile-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;}
.profile-eyebrow{text-align:center;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.profile-name{text-align:center;font-family:'Italiana',serif;font-size:28px;color:var(--cream);margin-bottom:28px;letter-spacing:.04em;}
.profile-divider{border:none;border-top:1px solid var(--line-soft);margin:24px 0;}
.profile-section-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.profile-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:4px;}
.profile-field{margin-bottom:16px;}
.profile-field label{display:block;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-dim);opacity:.75;margin-bottom:8px;}
.profile-field input{width:100%;background:rgba(255,255,255,.07);border:none;border-bottom:1px solid rgba(212,168,87,.3);padding:10px 4px;font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);outline:none;transition:border-color .3s;}
.profile-field input:focus{border-bottom-color:var(--gold);}
.profile-field input::placeholder{color:rgba(240,235,219,.25);}
.profile-contact-block{margin-top:6px;}
.profile-field input[readonly]{opacity:.75;cursor:not-allowed;}
.gender-btns{display:flex;gap:8px;flex-wrap:wrap;}
.gender-btn{flex:1;padding:9px 4px;background:transparent;border:1px solid rgba(212,168,87,.28);color:var(--cream-dim);font-family:'Cinzel',serif;font-size:8px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.gender-btn:hover{border-color:var(--gold);color:var(--gold);}
.gender-btn.active{background:rgba(212,168,87,.15);border-color:var(--gold);color:var(--gold-bright);}
.profile-save-btn{width:100%;padding:13px;background:var(--gold);border:none;color:var(--bg-deep);font-family:'Cinzel',serif;font-size:9px;letter-spacing:.28em;text-transform:uppercase;cursor:pointer;transition:all .3s;margin-top:4px;}
.profile-save-btn:hover{background:var(--gold-bright);letter-spacing:.34em;}
.profile-save-btn:disabled{opacity:.5;cursor:not-allowed;letter-spacing:.28em;}
.profile-msg{margin-top:12px;padding:11px 14px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;display:none;}
.profile-msg.success{display:block;background:rgba(52,168,83,.1);border:1px solid rgba(52,168,83,.35);color:#86efac;}
.profile-msg.error{display:block;background:rgba(139,26,26,.1);border:1px solid rgba(139,26,26,.35);color:#fca5a5;}

/* ── PROGRAMME DU JOUR ── */
.prog-map-wrap{
  position:relative;width:100%;max-width:820px;margin:20px 0;
  -webkit-mask-image: radial-gradient(ellipse 82% 72% at 50% 52%, black 28%, rgba(0,0,0,.65) 52%, transparent 76%);
  mask-image: radial-gradient(ellipse 82% 72% at 50% 52%, black 28%, rgba(0,0,0,.65) 52%, transparent 76%);
}
.prog-map-wrap canvas{display:block;width:100%;cursor:default;}
.prog-mlabel{position:absolute;text-align:center;cursor:pointer;transition:opacity .3s;}
.prog-mlabel:hover{opacity:1 !important;}
.prog-mlabel .num{font-family:'Cinzel',serif;font-weight:300;font-size:8px;letter-spacing:3px;color:var(--gold);opacity:.6;margin-bottom:5px;}
.prog-mlabel .mname{font-family:'Cinzel',serif;font-weight:400;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;margin-bottom:5px;transition:opacity .3s;}
.prog-mlabel .mtime{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:rgba(232,223,200,.55);}
#progTooltip{position:fixed;z-index:1000;pointer-events:none;opacity:0;transform:translateY(6px);transition:opacity .28s ease,transform .28s ease;width:240px;}
#progTooltip.visible{opacity:1;transform:translateY(0);}
@media(pointer:coarse){
  /* Sur écran tactile : tooltip ancré en bas, pleine largeur */
  #progTooltip{pointer-events:auto;bottom:24px !important;top:auto !important;left:50% !important;transform:translateX(-50%) translateY(10px);width:min(300px,calc(100vw - 32px));}
  #progTooltip.visible{transform:translateX(-50%) translateY(0);}
  /* Labels : plus grands et cliquables facilement */
  .prog-mlabel{padding:6px 2px;}
  .prog-mlabel .mname{font-size:9px;letter-spacing:1.5px;}
  .prog-mlabel .mtime{font-size:12px;}
}
.prog-tooltip-inner{background:rgba(10,13,40,.96);border:1px solid rgba(201,168,76,.22);padding:20px 22px 18px;position:relative;backdrop-filter:blur(16px);box-shadow:0 8px 40px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.03);}
.prog-tooltip-inner::before,.prog-tooltip-inner::after{content:'';position:absolute;width:10px;height:10px;border-color:rgba(201,168,76,.45);border-style:solid;}
.prog-tooltip-inner::before{top:-1px;left:-1px;border-width:1.5px 0 0 1.5px;}
.prog-tooltip-inner::after{bottom:-1px;right:-1px;border-width:0 1.5px 1.5px 0;}
.prog-tip-num{font-family:'Cinzel',serif;font-weight:300;font-size:8px;letter-spacing:3px;color:var(--gold);opacity:.7;margin-bottom:6px;}
.prog-tip-name{font-family:'Cinzel',serif;font-weight:400;font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;}
.prog-tip-time{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:rgba(232,223,200,.5);margin-bottom:14px;}
.prog-tip-divider{height:1px;background:linear-gradient(to right,rgba(201,168,76,.3),transparent);margin-bottom:14px;}
.prog-tip-detail{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:rgba(220,210,190,.75);line-height:1.7;margin-bottom:12px;}
.prog-tip-infos{display:flex;flex-direction:column;gap:6px;}
.prog-tip-info-row{display:flex;align-items:flex-start;gap:10px;}
.prog-tip-icon{font-size:10px;color:var(--gold);opacity:.7;margin-top:1px;flex-shrink:0;}
.prog-tip-text{font-family:'Cormorant Garamond',serif;font-size:12px;color:rgba(200,190,165,.55);line-height:1.5;}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  #burgerBtn{display:flex;align-items:center;justify-content:center}
  #sidebar{transform:translateX(-100%)}
  #sidebar.open{transform:translateX(0)}
  #sidebarOverlay.open{display:block}
  #mainContent{margin-left:0}
  .account-hero{padding:26px 18px 0}
  .account-hero .mission-edit-header{margin-bottom:22px}
  .mission-edit-header{margin-bottom:22px}
  .mission-edit-kicker{font-size:7px;letter-spacing:.34em;gap:10px;margin-bottom:8px}
  .mission-edit-kicker::before{width:28px}
  .mission-edit-kicker::after{display:none}
  .mission-edit-header h1{font-size:clamp(34px,12vw,50px);line-height:.95;margin-bottom:18px}
  .mission-edit-header h1 em{display:block;margin-left:0}
  .mission-header{margin-bottom:16px}
  .mission-header-kicker{font-size:7px;letter-spacing:.34em;gap:10px;margin-bottom:8px}
  .mission-header-kicker::before{width:28px}
  .mission-header-kicker::after{display:none}
  .mission-title{font-size:clamp(34px,12vw,50px);line-height:.95}
  .mission-phase-pill{margin-top:12px;font-size:8px;letter-spacing:.22em;padding:7px 12px}
  .mission-hero{grid-template-columns:1fr;gap:14px;padding:14px}
  .mission-hero-main{align-items:flex-start}
  .mission-avatar{width:66px;height:66px;font-size:24px}
  .mission-hero-name{font-size:26px}
  .mission-hero-status{font-size:15px}
  .mission-hero-count{font-size:8px;letter-spacing:.22em}
  .mission-points-orb{width:104px;height:104px;justify-self:end}
  .mission-points-value{font-size:40px}
  .mission-progress-card{padding:14px}
  .mission-progress-row{align-items:flex-start;flex-direction:column}
  .mission-progress-title{font-size:21px}
  .mission-trophy-grid{grid-template-columns:1fr}
  .mission-trophy-card{min-height:unset}
  .heroes-summary{grid-template-columns:1fr;gap:16px;padding:18px}
  .heroes-summary-title{font-size:clamp(32px,10vw,46px);margin-bottom:10px}
  .heroes-summary-text{font-size:15px}
  .heroes-summary-orb{min-width:132px;height:132px;justify-self:start}
  .heroes-summary-orb strong{font-size:40px}
  .heroes-grid{grid-template-columns:1fr}
  .heroes-card{padding:16px}
  .heroes-card-top{align-items:flex-start}
  .heroes-card-avatar{width:60px;height:60px;font-size:22px}
  .heroes-card-name{font-size:24px}
  .heroes-card-footer{align-items:flex-start;flex-direction:column}
  .heroes-card-points{text-align:left;min-width:0}
  .photo-challenge-summary{grid-template-columns:1fr;gap:16px;padding:18px}
  .photo-challenge-summary-title{font-size:clamp(32px,10vw,46px);margin-bottom:10px}
  .photo-challenge-summary-text{font-size:15px}
  .photo-challenge-summary-orb{min-width:132px;height:132px;justify-self:start}
  .photo-challenge-summary-orb strong{font-size:40px}
  .photo-challenge-meta{grid-template-columns:1fr}
  .photo-challenge-section-head{align-items:flex-start;flex-direction:column}
  .photo-challenge-grid{grid-template-columns:1fr}
  .photo-challenge-card{padding:16px}
  .photo-challenge-card-title{font-size:24px}
  .photo-challenge-modal{padding:16px}
  .photo-challenge-card-modal{padding:20px 18px;border-radius:22px}
  .photo-challenge-modal-head{margin-bottom:14px}
  .photo-challenge-modal-visual{min-height:260px}
  .photo-challenge-modal-cover{min-height:180px}
  .photo-challenge-modal-overlay{
    left:12px;
    right:12px;
    bottom:12px;
    padding:12px 14px;
    flex-direction:column;
    align-items:flex-start;
  }
  .photo-challenge-modal-latest{text-align:left}
  .photo-challenge-modal-copy{padding:18px}
  .photo-challenge-modal-title{font-size:36px}
  .photo-challenge-upload{grid-template-columns:1fr}
  .photo-challenge-upload-head{flex-direction:column}
  .photo-challenge-upload-card,
  .photo-challenge-comment-card{padding:18px}
  .photo-challenge-comment-card textarea{min-height:170px}
  .onboarding-hero,
  .time-machine-orbital{
    grid-template-columns:1fr;
  }
  .onboarding-steps,
  .time-machine-phase-grid,
  .time-machine-portal-grid{
    grid-template-columns:1fr;
  }
  .onboarding-section-head,
  .time-machine-section-head{
    flex-direction:column;
    align-items:flex-start;
  }
  .onboarding-hero,
  .time-machine-hero{padding:20px 18px}
  .onboarding-body,
  .time-machine-text{font-size:16px}
  .onboarding-step-title,
  .time-machine-phase-card-title{font-size:24px}
  .time-machine-orbital,
  .time-machine-phase-grid,
  .time-machine-portal-grid{
    grid-template-columns:1fr;
  }
  .time-machine-section-head{
    flex-direction:column;
    align-items:flex-start;
  }
  .time-machine-hero{padding:20px 18px}
  .time-machine-text{font-size:16px}
  .time-machine-orb-text span{font-size:16px}
  .time-machine-phase-card-title{font-size:24px}
  .pilot-report{grid-template-columns:auto 1fr;gap:12px;padding:12px 14px;text-align:left}
  .pilot-orb{width:44px;height:44px;font-size:22px;box-shadow:0 0 0 4px rgba(212,168,87,.1)}
  .pilot-report-kicker{font-size:6px;letter-spacing:.32em;margin-bottom:4px}
  .pilot-report-name{font-size:21px}
  .pilot-report-meta{gap:8px;margin-top:7px;font-size:8px;letter-spacing:.12em}
  .pilot-countdown{grid-column:1 / -1;border-left:none;border-top:1px solid rgba(251,244,225,.14);padding:9px 0 0;text-align:left;min-width:0;display:flex;align-items:baseline;gap:8px}
  .pilot-countdown span,.pilot-countdown small{font-size:7px;letter-spacing:.28em}
  .pilot-countdown strong{font-size:24px;margin:0}
  .page-inner{padding-left:18px;padding-right:18px;padding-bottom:56px}
  .homepage-phase-pill{margin-top:2px;font-size:8px;letter-spacing:.22em;padding:7px 12px}
  .edit-form .row{grid-template-columns:1fr}
  .rsvp-edit-card{padding:32px 22px}
  .response-cta{grid-template-columns:1fr;gap:14px;padding:28px 24px}
  .response-cta-btn{width:100%;white-space:normal}
  .infos-grid{grid-template-columns:1fr}
  .countdown-num{font-size:72px}
  .countdown-box{padding:24px 32px}
  .upload-zone{padding:28px 16px}
  .upload-steps{margin-bottom:24px}
  .folder-chips{gap:6px}
  .folder-chip{padding:7px 13px;font-size:14px}
  .group-member .gm-row{grid-template-columns:1fr}
  .profile-row{grid-template-columns:1fr}
  .group-teaser{padding:30px 24px 16px}
  .group-section{padding:18px 24px 30px}
  #saveGroupBtn{width:100%;margin-left:0}
  .group-member{grid-template-columns:1fr;gap:12px;text-align:left}
  .group-member-header{justify-content:flex-start}
  .crew-generator{padding:30px 18px 24px}
  .crew-generator-head{align-items:flex-start;flex-direction:column}
  .crew-generator-kicker::before,.crew-generator-kicker::after{width:20px;margin:0 8px}
  .crew-generator-title{font-size:30px}
  .crew-generator-count{white-space:normal}
  .crew-generator-actions{justify-content:stretch}
  .crew-btn{flex:1;min-width:180px}
  .mission-panel{grid-template-columns:repeat(3,1fr)}
  .mission-btn{grid-column:1 / -1;min-height:44px}
  .mission-stage{height:430px;min-height:430px}
  .mission-card-title{font-size:26px}
  .prog-map-wrap{margin:12px 0;}
}
@media(min-width:1400px){
  :root{ --sidebar-w: 280px; --account-content-w: 1080px; }
  .photo-grid{ grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
}

/* ============================================================
   QUIZ
============================================================ */
.quiz-inner { padding-bottom: 120px; }
.quiz-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 18px;
  align-items: stretch;
  margin-bottom: 22px;
}
.quiz-copy,
.quiz-orb,
.quiz-intro-panel,
.quiz-board,
.quiz-result-panel {
  background: rgba(10, 17, 46, 0.82);
  border: 1px solid rgba(212,168,87,.18);
  backdrop-filter: blur(14px);
  box-shadow: 0 28px 90px rgba(0,0,0,.28);
}
.quiz-copy { padding: 28px; }
.quiz-kicker,
.quiz-intro-title,
.quiz-result-badge,
.quiz-question-kicker {
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
}
.quiz-title {
  margin: 10px 0 12px;
  font-family: 'Italiana', serif;
  font-size: clamp(40px, 7vw, 64px);
  line-height: .9;
  color: var(--cream);
  font-weight: 400;
}
.quiz-title em { color: var(--gold-bright); font-style: italic; }
.quiz-text,
.quiz-intro-text,
.quiz-result-text {
  color: var(--cream-dim);
  font-size: 17px;
  line-height: 1.6;
}
.quiz-orb {
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  border-radius: 22px;
}
.quiz-orb span,
.quiz-orb small {
  font-family: 'Cinzel', serif;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 9px;
  color: var(--cream-dim);
}
.quiz-orb strong {
  margin: 8px 0 4px;
  font-family: 'Italiana', serif;
  font-size: 58px;
  line-height: 1;
  color: var(--gold-bright);
}
.quiz-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.quiz-summary-item,
.quiz-question-score {
  padding: 18px 20px;
  background: rgba(19,26,66,.62);
  border: 1px solid rgba(212,168,87,.16);
}
.quiz-summary-item span,
.quiz-question-score span {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--cream-dim);
  margin-bottom: 8px;
}
.quiz-summary-item strong,
.quiz-question-score strong {
  font-family: 'Italiana', serif;
  font-size: 34px;
  color: var(--gold-bright);
}
.quiz-intro-panel,
.quiz-board,
.quiz-result-panel {
  padding: 26px;
  border-radius: 24px;
}
.quiz-intro-actions,
.quiz-actions,
.quiz-result-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.quiz-btn {
  border: 1px solid var(--gold);
  color: var(--gold);
  background: transparent;
  padding: 12px 18px;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  cursor: pointer;
}
.quiz-btn.primary {
  background: var(--gold);
  color: var(--bg-deep);
}
.quiz-btn.secondary {
  border-color: rgba(250,245,232,.16);
  color: var(--cream-dim);
}
.quiz-btn:hover { filter: brightness(1.06); }
.quiz-question-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}
.quiz-question-meta {
  margin-top: 8px;
  color: var(--cream-dim);
  font-style: italic;
  font-size: 14px;
}
.quiz-photo-wrap {
  border-radius: 24px;
  overflow: hidden;
  min-height: 280px;
  background: linear-gradient(160deg, rgba(212,168,87,.1), rgba(9,15,40,.86));
  border: 1px solid rgba(212,168,87,.14);
  margin-bottom: 18px;
}
.quiz-photo-wrap img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}
.quiz-question-title {
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.08;
  color: var(--cream);
  margin-bottom: 18px;
}
.quiz-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.quiz-option {
  text-align: left;
  border: 1px solid rgba(212,168,87,.18);
  background: rgba(255,255,255,.03);
  color: var(--ink);
  padding: 18px 16px;
  min-height: 72px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  line-height: 1.35;
  cursor: pointer;
  transition: transform .2s, border-color .2s, background .2s;
}
.quiz-option:hover:not(:disabled) {
  transform: translateY(-2px);
  border-color: rgba(244,212,124,.55);
}
.quiz-option:disabled { cursor: default; }
.quiz-option.is-correct {
  background: rgba(88, 173, 118, .16);
  border-color: rgba(88, 173, 118, .55);
}
.quiz-option.is-wrong {
  background: rgba(181, 76, 76, .18);
  border-color: rgba(181, 76, 76, .55);
}
.quiz-feedback {
  margin-top: 16px;
  color: var(--cream-dim);
  font-style: italic;
  font-size: 15px;
  min-height: 24px;
}
.quiz-result-panel { text-align: center; }
.quiz-result-score {
  font-family: 'Italiana', serif;
  font-size: 76px;
  line-height: .95;
  color: var(--gold-bright);
  margin: 12px 0 10px;
}
.quiz-result-text {
  max-width: 680px;
  margin: 0 auto;
}
@media (max-width: 840px) {
  .quiz-hero,
  .quiz-summary {
    grid-template-columns: 1fr;
  }
  .quiz-question-head { flex-direction: column; }
  .quiz-photo-wrap,
  .quiz-photo-wrap img { min-height: 220px; }
  .quiz-result-score { font-size: 58px; }
}
