:root{
  --bordeaux:#7a2233;
  --bordeaux-soft:#9a4a5a;
  --ink:#4a2f36;
  --muted:#8a6a71;
  --muted-2:#9a6b62;
  --line:rgba(122,34,51,0.14);
  --card:rgba(255,255,255,0.55);
  --serif:'Cormorant Garamond',Georgia,serif;
  --display:'Rakkas','Cormorant Garamond',serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{
  font-family:var(--serif);
  color:var(--ink);
  background:linear-gradient(180deg,#d4e4f4 0%,#e3d9ee 34%,#f0dde6 64%,#f7ece2 100%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}

/* étoiles décoratives */
.page{position:relative;min-height:100vh;overflow:hidden}
.page::before,.page::after{
  content:"✦";position:fixed;color:rgba(255,255,255,.85);pointer-events:none;
  text-shadow:0 0 12px rgba(255,255,255,.7);
}
.page::before{top:8%;right:12%;font-size:22px}
.page::after{bottom:14%;left:9%;font-size:15px;color:#f4e2c4}

.view{
  max-width:440px;margin:0 auto;padding:30px 26px 44px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.hidden{display:none !important}

.wordmark{
  font-family:var(--serif);text-transform:uppercase;letter-spacing:.42em;
  color:var(--bordeaux);font-size:15px;font-weight:500;
}
.wordmark.tiny{font-size:11px;color:#b58c83;margin-top:26px}

.avatar{width:230px;max-width:74%;height:auto;margin:6px 0 2px;
  filter:drop-shadow(0 10px 26px rgba(122,34,51,.18))}

.display{font-family:var(--display);color:var(--bordeaux);font-weight:400;line-height:1.02}
#form-view .display{font-size:38px;margin-top:4px}
.tagline{font-size:16px;letter-spacing:.02em;color:var(--bordeaux-soft);margin:10px 14px 22px}

/* formulaire */
#profil-form{width:100%;display:flex;flex-direction:column;gap:11px}
.field-label{text-align:left;font-size:13px;letter-spacing:.04em;color:var(--muted-2);
  text-transform:uppercase;margin:6px 2px -4px}
#profil-form input{
  width:100%;font-family:var(--serif);font-size:17px;color:var(--ink);
  background:rgba(255,255,255,.62);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;outline:none;transition:border .15s,background .15s;
}
#profil-form input::placeholder{color:#b89aa0}
#profil-form input:focus{border-color:var(--bordeaux);background:rgba(255,255,255,.82)}
#profil-form input[type=date],#profil-form input[type=time]{color:var(--ink)}

.city-wrap{position:relative}
.suggestions{list-style:none;position:absolute;z-index:20;left:0;right:0;top:calc(100% + 4px);
  background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:0 12px 30px rgba(122,34,51,.14);display:none}
.suggestions.open{display:block}
.suggestions li{padding:11px 15px;font-size:16px;text-align:left;cursor:pointer;color:var(--ink)}
.suggestions li:hover,.suggestions li.active{background:#f6ebee;color:var(--bordeaux)}
.suggestions li .country{color:var(--muted);font-size:13px;margin-left:6px}

#submit-btn,.btn,.dl,.restart{font-family:var(--serif);cursor:pointer}
#submit-btn{
  margin-top:8px;background:var(--bordeaux);color:#fdf4ef;border:none;border-radius:12px;
  padding:15px;font-size:16px;letter-spacing:.16em;text-transform:uppercase;
  transition:transform .1s,background .15s;
}
#submit-btn:hover{background:#651b2b}
#submit-btn:active{transform:scale(.98)}
#submit-btn:disabled{opacity:.6;cursor:wait}
.form-error{color:#a3283b;font-size:15px;min-height:18px;margin-top:4px}

/* ═══ résultat ═══ */
#result-view .display.prenom{font-size:46px;text-transform:uppercase;margin-top:8px}
.birth{font-size:14px;letter-spacing:.08em;color:var(--bordeaux-soft);margin-top:7px}

.section-title{font-family:var(--serif);text-transform:uppercase;letter-spacing:.28em;
  font-size:12.5px;color:var(--bordeaux);margin:26px 0 12px}

.astro-list{width:100%;max-width:250px}
.astro-row{display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 2px;border-bottom:1px solid var(--line)}
.astro-row:last-child{border-bottom:none}
.astro-row .pl{font-size:17px;color:var(--muted)}
.astro-row .sign{font-family:var(--display);font-size:17px;color:var(--bordeaux)}

.hd-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;width:100%;max-width:330px}
.hd-cell{background:var(--card);border:1px solid var(--line);border-radius:13px;
  padding:13px 8px;text-align:center}
.hd-cell .k{text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;color:var(--muted-2);margin-bottom:4px}
.hd-cell .v{font-family:var(--display);font-size:17px;color:var(--bordeaux);line-height:1.1}

/* roue affichée à l'écran (screenshotable) */
.wheel-box{width:100%;max-width:380px;margin:8px auto 0}
.wheel-box svg{width:100%;height:auto;display:block}
.wheel-loading{font-family:var(--serif);font-style:italic;color:var(--muted-2);padding:50px 0;text-align:center;font-size:16px}
.wheel-leg{width:100%;max-width:370px;background:rgba(255,255,255,.4);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-top:16px;text-align:left}
.wl-title{font-family:var(--serif);text-transform:uppercase;letter-spacing:.28em;font-size:12px;color:var(--bordeaux);text-align:center;margin-bottom:12px;font-weight:600}
.wl-li{font-family:var(--serif);font-size:15px;line-height:1.5;color:#7c565e;margin-bottom:8px}
.wl-li:last-child{margin-bottom:0}
.wl-li b{color:var(--bordeaux);font-weight:600}
.shot-hint{font-family:var(--serif);font-style:italic;color:var(--muted-2);font-size:15px;text-align:center;margin-top:18px;letter-spacing:.02em}

.tunnel{background:rgba(255,255,255,.38);border:1px solid var(--line);border-radius:15px;
  padding:18px 18px;margin:26px 0 6px;max-width:360px}
.tunnel p{font-size:16px;line-height:1.6;color:var(--ink)}
.tunnel p+p{margin-top:10px}

.cta{display:flex;flex-direction:column;gap:10px;width:100%;max-width:330px;margin-top:18px}
.btn{text-decoration:none;text-align:center;padding:14px;border-radius:12px;
  letter-spacing:.16em;text-transform:uppercase;font-size:14px;transition:transform .1s}
.btn:active{transform:scale(.98)}
.btn-solid{background:var(--bordeaux);color:#fdf4ef}
.btn-outline{border:1px solid var(--bordeaux);color:var(--bordeaux)}

.downloads{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.dl{background:none;border:none;color:var(--muted-2);font-size:14.5px;letter-spacing:.04em;padding:6px}
.dl:hover{color:var(--bordeaux)}
.restart{background:none;border:none;color:#b58c83;font-size:14px;margin-top:20px;letter-spacing:.06em}

/* ═══ carte export 1080×1350 (hors écran) ═══ */
#export-card{position:fixed;left:-3000px;top:0;width:1080px;height:1350px}
.ec-inner{width:1080px;min-height:1350px;position:relative;
  background:linear-gradient(180deg,#d6e5f4 0%,#e5dbee 34%,#f1dee6 64%,#f8ede3 100%);
  display:flex;flex-direction:column;align-items:center;padding:70px 80px;color:var(--ink)}
.ec-wordmark{font-family:var(--serif);text-transform:uppercase;letter-spacing:.5em;
  color:var(--bordeaux);font-size:34px}
.ec-avatar{width:300px;height:auto;margin:10px 0 4px;
  filter:drop-shadow(0 14px 30px rgba(122,34,51,.2))}
.ec-prenom{font-family:var(--display);font-size:78px;color:var(--bordeaux);text-transform:uppercase;line-height:1}
.ec-birth{font-family:var(--serif);font-size:30px;letter-spacing:.06em;color:var(--bordeaux-soft);margin-top:8px}
.ec-sep{width:180px;height:2px;background:rgba(122,34,51,.3);margin:20px 0}
.ec-section{font-family:var(--serif);text-transform:uppercase;letter-spacing:.32em;
  font-size:26px;color:var(--bordeaux);margin:6px 0 14px}
.ec-astro{display:grid;grid-template-columns:1fr 1fr;gap:6px 60px;width:760px;margin-bottom:6px}
.ec-astro .r{display:flex;justify-content:space-between;border-bottom:1px solid rgba(122,34,51,.16);padding:9px 0}
.ec-astro .r .pl{font-family:var(--serif);font-size:30px;color:var(--muted)}
.ec-astro .r .sign{font-family:var(--display);font-size:30px;color:var(--bordeaux)}
.ec-hd{display:flex;gap:24px;margin-top:6px}
.ec-hd .c{text-align:center}
.ec-hd .c .k{font-family:var(--serif);text-transform:uppercase;letter-spacing:.1em;font-size:19px;color:var(--muted-2)}
.ec-hd .c .v{font-family:var(--display);font-size:30px;color:var(--bordeaux);margin-top:4px}
.ec-foot{margin-top:40px;padding-bottom:20px;font-family:var(--serif);letter-spacing:.4em;
  text-transform:uppercase;font-size:22px;color:#b58c83}

/* ═══ roue export 1080 large (hors écran) ═══ */
#export-wheel{position:fixed;left:-4000px;top:0;width:1080px}
.ew-inner{width:1080px;background:linear-gradient(180deg,#d4e4f4 0%,#e3d9ee 30%,#f0dde6 55%,#f7ece2 100%);
  display:flex;flex-direction:column;align-items:center;padding:60px 70px 50px;color:var(--ink)}
.ew-name{font-family:var(--display);color:var(--bordeaux);font-size:80px;text-transform:uppercase;letter-spacing:3px;line-height:1}
.ew-sub{font-family:var(--serif);color:var(--bordeaux-soft);font-size:36px;letter-spacing:.06em;margin-top:6px;margin-bottom:6px}
.ew-wheel{width:900px;margin:6px 0}
.ew-wheel svg{width:900px;height:auto;display:block}
.ew-leg{width:820px;background:rgba(255,255,255,.4);border:1px solid var(--line);border-radius:20px;padding:30px 36px;margin-top:14px}
.ew-legtitle{font-family:var(--serif);text-transform:uppercase;letter-spacing:.3em;font-size:22px;color:var(--bordeaux);text-align:center;margin-bottom:18px;font-weight:600}
.ew-li{font-family:var(--serif);font-size:27px;line-height:1.5;color:#7c565e;margin-bottom:12px}
.ew-li b{color:var(--bordeaux);font-weight:600}
.ew-date{font-family:var(--serif);color:var(--bordeaux);font-size:42px;letter-spacing:.08em;margin-top:34px}
.ew-city{font-family:var(--serif);color:var(--bordeaux-soft);font-size:34px}
.ew-sig{font-family:var(--serif);color:#b98a3e;font-size:30px;letter-spacing:.5em;margin-top:22px}
