:root{
  --bg:#1a1917;
  --surface:#232120;
  --surface-2:#2b2825;
  --line:#38342e;
  --line-soft:#2f2c27;
  --text:#ece7df;
  --dim:#a39d93;
  --faint:#736d64;

  --sage:#b7c489;
  --sage-deep:#8f9c62;
  --sage-soft:rgba(183,196,137,.12);
  --blush:#e9b48f;
  --blush-soft:rgba(233,180,143,.14);
  --clay:#cf9384;
  --clay-soft:rgba(207,147,132,.12);

  --serif:'Times New Roman', Times, serif;
  --sans:'Times New Roman', Times, serif;

  --r:14px;
  --r-lg:22px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* hide scrollbars everywhere but keep scrolling */
*{scrollbar-width:none;-ms-overflow-style:none}
*::-webkit-scrollbar{width:0;height:0;display:none}

:root{ --appw:600px; }

html,body{height:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  display:flex;justify-content:center;align-items:stretch;
}

/* the app fills the whole window at every size; content is centered in a readable column */
#phone{
  width:100%;
  min-height:100dvh;
  background:
    radial-gradient(120% 55% at 50% -8%, rgba(183,196,137,.05), transparent 60%),
    var(--bg);
  position:relative;
  display:flex;flex-direction:column;
  overflow:hidden;
}

#app{flex:1;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}
.screen{flex:1;display:flex;flex-direction:column;width:100%;max-width:var(--appw);margin-inline:auto;padding:26px 22px 30px;animation:rise .5s var(--ease) both}
.screen.center{justify-content:center}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media(min-width:700px){
  .screen{padding:44px 22px 40px}
}

/* ---------- type ---------- */
.wordmark{font-family:var(--serif);font-weight:400;font-size:26px;letter-spacing:.01em;color:var(--text)}
.wordmark .dot{color:var(--sage)}
h1{font-family:var(--serif);font-weight:400;font-size:30px;line-height:1.15;letter-spacing:-.01em}
h2{font-family:var(--serif);font-weight:400;font-size:23px;line-height:1.2}
.eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:600}
.lede{color:var(--dim);font-size:15px;margin-top:10px}
.muted{color:var(--dim)}
.faint{color:var(--faint)}
.tiny{font-size:12.5px}
.serif{font-family:var(--serif)}
.center-t{text-align:center}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--sans);font-weight:600;font-size:15.5px;
  border:none;border-radius:var(--r);padding:15px 18px;width:100%;
  background:var(--sage);color:#20200f;cursor:pointer;
  transition:transform .12s var(--ease),filter .2s,box-shadow .2s;
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset;
}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:scale(.98)}
.btn:disabled{opacity:.45;cursor:default;transform:none;filter:none}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--sage-deep);background:var(--sage-soft)}
.btn.subtle{background:var(--surface-2);color:var(--text)}
.btn.subtle:hover{background:#332f2a}
.btn.sm{width:auto;padding:9px 14px;font-size:13px;border-radius:10px}
.btn-row{display:flex;gap:10px}
.btn-row .btn{width:100%}
.stack>*{margin-top:12px}
.linkish{color:var(--sage);cursor:pointer;font-weight:600}
.linkish:hover{text-decoration:underline}

/* ---------- inputs ---------- */
.field{margin-top:16px}
.field label{display:block;font-size:13px;color:var(--dim);margin-bottom:7px;font-weight:600}
input,select,textarea{
  width:100%;font-family:var(--sans);font-size:15px;color:var(--text);
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 15px;
  transition:border-color .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--sage-deep);box-shadow:0 0 0 3px var(--sage-soft)}
input::placeholder,textarea::placeholder{color:var(--faint)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a39d93' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
textarea{resize:none;line-height:1.5}
.err{background:var(--clay-soft);border:1px solid var(--clay);color:var(--clay);
  padding:11px 13px;border-radius:11px;font-size:13.5px;margin-top:14px}

/* ---------- header ---------- */
.top{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 6px}
.top .day{font-size:13px;color:var(--dim);font-weight:600}

/* ---------- folds progress ---------- */
.folds{display:flex;gap:5px;align-items:flex-end;height:26px;margin:16px 0 4px}
.fold{flex:1;height:12px;border-radius:3px;background:var(--line-soft);transition:all .4s var(--ease)}
.fold.done{background:var(--sage);height:20px}
.fold.now{background:var(--blush);height:26px;box-shadow:0 0 12px var(--blush-soft);animation:breathe 2.4s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.75}50%{opacity:1}}

/* ---------- cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}
.card+.card{margin-top:12px}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px}

/* ---------- name (review) ---------- */
.namewrap{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:20px 0}
.bigname{font-family:var(--serif);font-weight:400;font-size:clamp(46px,15vw,66px);line-height:1.02;color:var(--text)}
.namecard-anim{animation:namein .34s var(--ease) both}
@keyframes namein{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
.notetoggle{margin-top:22px;color:var(--faint);font-size:13.5px;cursor:pointer;border-bottom:1px dotted var(--faint);padding-bottom:2px}
.notetoggle:hover{color:var(--dim)}
.notebox{width:100%;margin-top:16px}

.votes{display:flex;gap:10px;padding-top:6px}
.vote{flex:1;border:1px solid var(--line);background:var(--surface);border-radius:14px;
  padding:15px 8px 13px;cursor:pointer;color:var(--text);font-weight:600;font-size:14px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  transition:transform .12s var(--ease),border-color .2s,background .2s}
.vote:active{transform:scale(.96)}
.vote .g{font-family:var(--serif);font-size:20px;line-height:1}
.vote.no:hover{border-color:var(--clay);background:var(--clay-soft);color:var(--clay)}
.vote.ok:hover{border-color:var(--dim);background:var(--surface-2)}
.vote.love:hover{border-color:var(--blush);background:var(--blush-soft);color:var(--blush)}
.countline{text-align:center;color:var(--faint);font-size:12.5px;margin-top:16px}

/* ---------- chips / verdicts ---------- */
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:999px;padding:7px 12px;font-size:13px;margin:4px 6px 4px 0}
.chip .x{color:var(--clay);cursor:pointer;font-weight:700;line-height:1}
.chip .why{color:var(--faint);font-size:12px}
.verdict{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 10px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface-2);color:var(--dim)}
.verdict.love{color:var(--blush);border-color:rgba(233,180,143,.4);background:var(--blush-soft)}
.verdict.no{color:var(--clay);border-color:rgba(207,147,132,.4);background:var(--clay-soft)}
.verdict.chose{color:var(--sage);border-color:var(--sage-deep);background:var(--sage-soft)}

/* ---------- reveal ---------- */
.gem{background:linear-gradient(180deg,var(--blush-soft),transparent),var(--surface);
  border:1px solid rgba(233,180,143,.35);border-radius:var(--r-lg);padding:22px;position:relative;overflow:hidden}
.gem+.gem{margin-top:12px}
.gem .gname{font-family:var(--serif);font-size:36px;line-height:1.05;color:var(--text)}
.gem .glow{position:absolute;inset:auto -40px -60px auto;width:160px;height:160px;
  background:radial-gradient(circle,var(--blush-soft),transparent 70%);pointer-events:none}
.rankrow{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-top:1px solid var(--line-soft)}
.rankrow:first-child{border-top:none}
.rank-n{font-family:var(--serif);font-size:20px;color:var(--sage);min-width:26px;text-align:right;padding-top:2px}
.rank-name{font-family:var(--serif);font-size:24px;line-height:1.1;color:var(--text)}
.bar{height:6px;border-radius:3px;background:var(--line-soft);overflow:hidden;margin:10px 0 8px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--sage-deep),var(--sage));border-radius:3px}
.notela{font-size:13px;color:var(--dim);font-style:italic;margin-top:5px;font-family:var(--serif)}
.notela b{color:var(--sage);font-style:normal;font-family:var(--sans);font-weight:600;font-size:12px}
.secret{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--blush);font-weight:600}

/* ---------- bottom nav ---------- */
.nav{display:flex;border-top:1px solid var(--line);background:rgba(26,25,23,.92);backdrop-filter:blur(10px);
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));flex-shrink:0;
  width:100%;max-width:var(--appw);margin-inline:auto}
.nav a{flex:1;text-align:center;padding:9px 4px;color:var(--faint);font-size:12px;font-weight:600;cursor:pointer;
  border-radius:12px;transition:color .2s,background .2s}
.nav a .ic{display:block;font-family:var(--serif);font-size:19px;margin-bottom:2px}
.nav a.on{color:var(--sage)}
.nav a:hover{color:var(--dim)}

/* ---------- misc ---------- */
.codebox{font-family:var(--serif);font-size:34px;letter-spacing:.22em;text-align:center;color:var(--sage);
  background:var(--surface);border:1px dashed var(--sage-deep);border-radius:var(--r);padding:20px;margin-top:16px}
.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--sage);margin-right:7px;
  animation:breathe 1.8s ease-in-out infinite;vertical-align:middle}
.divider{height:1px;background:var(--line-soft);margin:20px 0}
.spread{display:flex;justify-content:space-between;align-items:center;gap:10px}
.grow{flex:1}
.hidden{display:none}
.count-big{font-family:var(--serif);font-size:44px;color:var(--sage);letter-spacing:.02em}

/* landing: how it works */
.howrow{display:flex;gap:12px;align-items:flex-start;margin-top:14px;font-size:14px;color:var(--dim);line-height:1.5}
.hown{flex:none;width:24px;height:24px;border-radius:50%;border:1px solid var(--sage-deep);color:var(--sage);
  font-family:var(--serif);font-size:14px;display:flex;align-items:center;justify-content:center;margin-top:1px}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
