/* Velvet Over Iron — styles */
:root{
  --ink:#2b211d; --ink-soft:#6a5d54; --paper:#f4ece2; --paper-2:#ece0d2; --card:#fbf6ee;
  --wine:#7a2638; --wine-soft:#a8475a; --gold:#b08543; --line:#d8c9b6;
  --green:#3f6f54; --amber:#b07a2c; --grey:#8a7d72; --ink-1:#1f3a5f;
  --shadow:0 18px 48px -22px rgba(60,30,20,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Newsreader',Georgia,serif;color:var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%,#f7efe4,transparent),
    radial-gradient(900px 500px at -10% 110%,#efe2d1,transparent),
    var(--paper);
  min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.wrap{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:0 20px}
.screen{display:none;animation:fade .45s ease both}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.hidden{display:none!important}
.center{text-align:center}

/* type */
.eyebrow{font-family:'Fraunces',serif;font-style:italic;letter-spacing:.07em;color:var(--wine-soft);font-size:.92rem}
h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.2rem,7vw,3.6rem);line-height:1.04;letter-spacing:-.01em;margin:.1em 0 .12em}
h1 em{font-style:italic;color:var(--wine)}
h2{font-family:'Fraunces',serif;font-weight:400}
.sub{font-size:1.06rem;color:var(--ink-soft);max-width:540px;margin:12px auto 0}
.muted{color:var(--grey);font-size:.9rem}
.rule{width:54px;height:1px;background:var(--gold);margin:24px auto;position:relative}
.rule::before,.rule::after{content:"";position:absolute;top:50%;width:5px;height:5px;border-radius:50%;background:var(--gold);transform:translateY(-50%)}
.rule::before{left:-11px}.rule::after{right:-11px}

/* buttons */
.btn{font-family:'Fraunces',serif;font-size:1rem;cursor:pointer;border:none;padding:13px 26px;border-radius:38px;background:var(--wine);color:#fbf3ea;transition:.22s}
.btn:hover{background:#621d2c;transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(122,38,56,.6)}
.btn:disabled{opacity:.42;cursor:default;transform:none;box-shadow:none}
.btn.ghost{background:transparent;color:var(--wine);border:1px solid var(--wine)}
.btn.ghost:hover{background:var(--wine);color:#fbf3ea}
.btn.small{padding:8px 18px;font-size:.9rem}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* cards / panels */
.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 26px;box-shadow:var(--shadow);margin:18px 0}
.panel h2{font-size:1.35rem;margin-bottom:.5em;color:var(--wine)}
.panel p{margin-bottom:.7em;color:var(--ink-soft)}.panel p:last-child{margin-bottom:0}
.panel strong{color:var(--ink);font-weight:500}

/* inputs */
.field{width:100%;font-family:'Fraunces',serif;font-size:1.05rem;text-align:center;padding:12px 16px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.field:focus{outline:none;border-color:var(--wine-soft)}
label.lab{display:block;font-family:'Fraunces',serif;font-style:italic;color:var(--grey);font-size:.85rem;margin:0 0 6px}
textarea.note{width:100%;font-family:'Newsreader',serif;font-size:.97rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 12px;resize:vertical;min-height:54px}
textarea.note:focus{outline:none;border-color:var(--wine-soft)}

/* login */
.login-wrap{min-height:80vh;display:flex;flex-direction:column;justify-content:center}
.login-card{max-width:380px;margin:0 auto;width:100%}
.login-card .field{margin-bottom:12px}
.err{color:var(--wine);font-size:.9rem;min-height:1.2em;text-align:center}

/* home */
.slots{display:flex;gap:16px;flex-wrap:wrap;margin:18px 0}
.slot{flex:1 1 240px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--shadow)}
.slot h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.25rem}
.slot .status{font-family:'Fraunces',serif;font-style:italic;font-size:.92rem;margin:6px 0 12px}
.status.notstarted{color:var(--grey)} .status.inprogress{color:var(--amber)} .status.sealed{color:var(--wine)} .status.revealed{color:var(--green)}
.mode-pills,.tone-pills{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.mode-pills button,.tone-pills button{font-family:'Fraunces',serif;font-size:.84rem;cursor:pointer;padding:7px 14px;border-radius:30px;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);transition:.2s}
.mode-pills button.on,.tone-pills button.on{background:var(--wine);color:#fbf3ea;border-color:transparent}

/* questionnaire: full screen card */
#fillScreen .wrap{max-width:640px}
.qtop{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:14px 0 8px}
.qtop .qx{font-family:'Fraunces',serif;font-size:.9rem;color:var(--grey)}
.qprog{flex:1;height:6px;background:var(--paper-2);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.qprog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--wine-soft),var(--wine));transition:width .35s}
.qcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px 26px 30px;box-shadow:var(--shadow);min-height:60vh;display:flex;flex-direction:column}
.qsec{font-family:'Fraunces',serif;font-style:italic;font-size:.82rem;letter-spacing:.06em;color:var(--gold);text-transform:uppercase}
.qcat{font-family:'Fraunces',serif;font-size:.9rem;color:var(--wine-soft);margin-top:2px}
.qtext{font-family:'Fraunces',serif;font-weight:400;font-size:1.55rem;line-height:1.28;margin:10px 0 6px;color:var(--ink)}
.qhint{font-size:.96rem;color:var(--grey);font-style:italic;margin-bottom:18px}

.slider{-webkit-appearance:none;appearance:none;width:100%;height:9px;border-radius:9px;
  background:linear-gradient(90deg,var(--wine) 0%,#caa68a 28%,#e7dccb 50%,#9cbf9f 72%,var(--green) 100%);outline:none;cursor:pointer}
.slider.untouched{filter:saturate(.5) opacity(.8)}
.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:#fbf6ee;border:3px solid var(--wine);box-shadow:0 3px 10px -2px rgba(0,0,0,.35);cursor:grab}
.slider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:#fbf6ee;border:3px solid var(--wine);box-shadow:0 3px 10px -2px rgba(0,0,0,.35);cursor:grab}
.slabels{display:flex;justify-content:space-between;gap:10px;margin-top:10px;font-size:.85rem}
.slabels .l{color:var(--wine);max-width:42%;line-height:1.25}
.slabels .r{color:var(--green);max-width:42%;text-align:right;line-height:1.25}
.readout{text-align:center;font-family:'Fraunces',serif;font-style:italic;font-size:.95rem;margin:12px 0 2px;color:var(--grey);min-height:1.3em}
.readout.set{color:var(--ink)}

.chiprow{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}
.chip-opt{font-family:'Newsreader',serif;font-size:.86rem;cursor:pointer;padding:6px 12px;border-radius:20px;border:1px solid var(--line);background:#fff;color:var(--ink-soft);transition:.16s}
.chip-opt.on{background:var(--wine-soft);color:#fff;border-color:transparent}
.chip-label{font-family:'Fraunces',serif;font-style:italic;font-size:.8rem;color:var(--grey);margin:12px 0 2px}

.qextra{margin-top:14px}
.qextra summary{cursor:pointer;font-family:'Fraunces',serif;font-style:italic;color:var(--wine-soft);font-size:.9rem;list-style:none}
.qextra summary::-webkit-details-marker{display:none}
.qextra[open] summary{margin-bottom:10px}
.spacer{flex:1}
.qnav{display:flex;gap:10px;justify-content:space-between;margin-top:20px;flex-wrap:wrap}
.qnav .left,.qnav .right{display:flex;gap:8px;flex-wrap:wrap}

/* reveal */
.seal-box{text-align:center;padding:10px 0}

/* review */
.cmp-row{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin:11px 0}
.cmp-row.match{border-color:var(--green)} .cmp-row.gap{border-color:var(--amber)} .cmp-row.limit{border-color:var(--wine)}
.cmp-row .cat{font-family:'Fraunces',serif;font-style:italic;font-size:.78rem;color:var(--gold);text-transform:uppercase;letter-spacing:.06em}
.cmp-row .qtext2{font-size:1.02rem;margin:4px 0 10px;font-family:'Newsreader',serif}
.meter{position:relative;height:28px;border-radius:8px;background:linear-gradient(90deg,var(--wine) 0%,#caa68a 28%,#e7dccb 50%,#9cbf9f 72%,var(--green) 100%);opacity:.85;margin:4px 0}
.mk{position:absolute;top:50%;width:17px;height:17px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.mk.a{background:var(--wine)} .mk.b{background:var(--ink-1)}
.mlabels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--grey);margin-top:2px}
.legend{text-align:center;font-size:.82rem;color:var(--ink-soft);margin-bottom:6px}
.legend .da{color:var(--wine);font-weight:600}.legend .db{color:var(--ink-1);font-weight:600}
.notes2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
@media(max-width:520px){.notes2{grid-template-columns:1fr}}
.notes2 .nm{font-size:.74rem;color:var(--grey);text-transform:uppercase;font-family:'Fraunces',serif}
.notes2 .nt{font-size:.92rem;color:var(--ink-soft);font-style:italic}
.flag{font-family:'Fraunces',serif;font-style:italic;font-size:.82rem;margin-top:8px}
.flag.green{color:var(--green)}.flag.amber{color:var(--amber)}.flag.red{color:var(--wine)}
.aiblock{background:linear-gradient(180deg,#fbf6ee,#f6ece0);border:1px solid var(--line);border-radius:16px;padding:24px 26px;margin:18px 0;box-shadow:var(--shadow)}
.aiblock h2{font-size:1.4rem;color:var(--wine);margin-bottom:.4em}
.aiblock h1,.aiblock h2,.aiblock h3{font-family:'Fraunces',serif;font-weight:400}
.aiblock h3{font-size:1.1rem;color:var(--wine-soft);margin:.8em 0 .3em}
.aiblock p{margin-bottom:.7em}
.aiblock ul{margin:.2em 0 .8em 1.1em}.aiblock li{margin-bottom:.25em}
.aiblock .loading{color:var(--grey);font-style:italic}
.filterbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:14px 0}
.filterbar button{font-family:'Fraunces',serif;font-size:.84rem;cursor:pointer;padding:7px 14px;border-radius:30px;border:1px solid var(--line);background:var(--card);color:var(--ink-soft)}
.filterbar button.on{background:var(--wine);color:#fbf3ea;border-color:transparent}

/* chat */
.chat-log{display:flex;flex-direction:column;gap:10px;margin:14px 0;max-height:50vh;overflow-y:auto;padding:4px}
.msg{padding:11px 14px;border-radius:12px;max-width:85%;font-size:.97rem}
.msg.user{align-self:flex-end;background:var(--wine);color:#fbf3ea;border-bottom-right-radius:3px}
.msg.assistant{align-self:flex-start;background:var(--card);border:1px solid var(--line);border-bottom-left-radius:3px}
.chat-in{display:flex;gap:8px;margin-top:6px}
.chat-in input{flex:1;font-family:'Newsreader',serif;font-size:.97rem;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:#fff}
.chat-in input:focus{outline:none;border-color:var(--wine-soft)}

/* misc */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fbf3ea;padding:10px 18px;border-radius:30px;font-size:.9rem;z-index:200;opacity:0;transition:.3s;pointer-events:none}
.toast.show{opacity:.96}
.codebox{width:100%;font-family:ui-monospace,monospace;font-size:.78rem;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:9px;padding:11px;resize:vertical;min-height:90px;word-break:break-all}
footer{text-align:center;padding:34px 0 60px;color:var(--grey);font-size:.82rem;font-style:italic}
a{color:var(--wine)}
::selection{background:var(--wine-soft);color:#fff}
@media print{
  body::before,.btn,.filterbar,.chat-in,.qnav,.topnav{display:none!important}
  .panel,.aiblock,.cmp-row{box-shadow:none;border-color:#ccc}
}
