/* ===== PostSorted — shared styles ===== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=DM+Sans:wght@400;500;700&display=swap');

:root{
  --cream:#FBF7F0; --card:#ffffff; --ink:#2B2722; --muted:#8A8178; --soft:#5b544c;
  --terra:#E07A5F; --terra-dark:#C9614A; --green:#3D8361; --amber:#BA7517;
  --line:#ECE4D8; --line-soft:#F1EFE8; --peach:#FBEDE7; --peach-line:#F2D9CF;
  --radius:18px; --shadow:0 12px 30px -16px rgba(43,39,34,.22);
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'DM Sans',system-ui,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:clip}
.serif{font-family:'Fraunces',serif}
a{color:inherit}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* layout */
.wrap{max-width:600px;margin:0 auto;padding:0 16px}
.narrow{max-width:480px}
.page{min-height:100vh;display:flex;flex-direction:column}

/* nav */
.nav{display:flex;align-items:center;justify-content:space-between;height:58px;max-width:600px;margin:0 auto;padding:0 16px}
.brand{font-family:'Fraunces',serif;font-weight:700;font-size:20px;display:flex;gap:8px;align-items:center;text-decoration:none}
.dot{width:10px;height:10px;border-radius:50%;background:var(--terra)}
.nav-r{display:flex;gap:12px;align-items:center;font-size:14px;color:var(--muted)}
.nav-r a{text-decoration:none}
.ghost-sm{border:1px solid var(--line);border-radius:999px;padding:6px 13px;color:var(--ink);font-weight:500;text-decoration:none}

/* type */
h1.title{font-family:'Fraunces',serif;font-weight:700;font-size:27px;margin:0 0 4px}
.eyebrow{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);font-weight:700;margin:0 0 8px}
.sub{color:var(--muted);margin:0 0 18px;font-size:15px}

/* card + form */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
label.lbl{font-weight:500;font-size:14px;margin:0 0 6px;display:block}
.opt{color:#B0A89C;font-weight:400}
.req{color:var(--terra)}
.help{font-size:12px;color:var(--muted);margin:0 0 7px}
.field{margin-bottom:16px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
input.inp,select.inp,textarea.inp{width:100%;font-size:15px;border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;color:var(--ink);background:#fff;font-family:inherit}
textarea.inp{min-height:62px;resize:vertical}
input.inp:focus,select.inp:focus,textarea.inp:focus{outline:none;border-color:var(--terra)}
input.readonly{background:#f6f1e8;color:var(--muted)}
.counter{font-size:12px;color:var(--muted);text-align:right;margin:4px 0 0}
.counter.over{color:#c0563c}

/* file input */
.filebox{border:1.5px dashed var(--line);border-radius:12px;padding:12px;color:var(--muted);font-size:14px;cursor:pointer}
.filebox.has{color:var(--ink);border-color:var(--green)}
input[type=file]{display:none}

/* buttons */
.btn{display:inline-block;border:0;border-radius:999px;padding:13px 24px;font-size:16px;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;font-family:inherit}
.btn-primary{background:var(--terra);color:#fff;width:100%}
.btn-green{background:var(--green);color:#fff;width:100%}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn[disabled]{opacity:.55;cursor:not-allowed}

/* chips (tone) */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid var(--line);border-radius:999px;padding:8px 14px;font-size:14px;font-weight:600;color:var(--soft);background:#fff;cursor:pointer;user-select:none}
.chip.sel{background:var(--terra);color:#fff;border-color:var(--terra)}

/* square style picker */
.pick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pick .opt-tile{position:relative;border:2px solid var(--line);border-radius:14px;overflow:hidden;aspect-ratio:1;cursor:pointer}
.pick .opt-tile.sel{border-color:var(--terra)}
.pick .swz{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;color:#fff;font-weight:700;font-size:13px;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.pick .tick{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--terra);color:#fff;display:none;align-items:center;justify-content:center;font-size:13px}
.pick .opt-tile.sel .tick{display:flex}

/* colour pickers */
.colors{display:flex;gap:12px;flex-wrap:wrap}
.color-chip{display:flex;align-items:center;gap:9px;border:1.5px solid var(--line);border-radius:12px;padding:7px 12px;cursor:pointer}
.color-chip .dab{width:26px;height:26px;border-radius:7px;border:1px solid rgba(0,0,0,.1)}
.color-chip input[type=color]{width:0;height:0;opacity:0;position:absolute}
.color-chip .hex{font-size:13px;color:var(--soft)}

/* contact + toggle */
.contact{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.contact-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.tg-label{font-size:13px;color:var(--muted)}
.switch{width:40px;height:23px;border-radius:999px;background:#E0D9CD;position:relative;cursor:pointer;flex:none}
.switch.on{background:var(--green)}
.switch .knob{position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:left .15s}
.switch.on .knob{left:18px}

/* feature blocks (month form) */
.feat{border:1px solid var(--line);border-radius:14px;padding:15px;margin-bottom:13px}
.feat h3{font-size:15px;font-weight:700;margin:0 0 3px}

/* info / intro boxes */
.intro{background:var(--peach);border:1px solid var(--peach-line);border-radius:14px;padding:15px 16px;margin:14px 0 16px}
.intro p{margin:0;font-size:13.5px;color:#7a4634;line-height:1.55}
.mix-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.mtag{background:#fff;border:1px solid var(--peach-line);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;color:var(--terra-dark)}

/* dashboard next-step + states */
.state{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 22px;text-align:center}
.ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:25px}
.ic-a{background:var(--peach);color:var(--terra)}
.ic-w{background:#FAEEDA;color:var(--amber)}
.ic-g{background:#EAF3DE;color:#3B6D11}
.state h2{font-family:'Fraunces',serif;font-weight:700;font-size:21px;margin:0 0 5px}
.state p{color:var(--muted);margin:0;font-size:14px}
.card-soft{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:14px}
.plan-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px}
.pill{background:var(--line-soft);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--muted)}

/* order pipeline */
.pipe-head{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:18px 20px 0}
.pipe{display:flex;padding:14px 20px 8px;gap:4px}
.pstep{flex:1;text-align:center}
.pbar{height:5px;border-radius:5px;background:var(--line);margin-bottom:6px}
.pstep.done .pbar,.pstep.cur .pbar{background:var(--terra)}
.plabel{font-size:10px;color:#B0A89C;font-weight:600}
.pstep.cur .plabel{color:var(--terra-dark);font-weight:700}
.pnote{text-align:center;color:var(--muted);font-size:13px;padding:0 20px 18px}

/* summary review */
.summary{background:#fff;border:1px solid var(--line);border-radius:16px;padding:6px 18px;box-shadow:var(--shadow)}
.srow{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.srow:last-child{border-bottom:0}
.skey{color:var(--muted)}
.sval{font-weight:600;text-align:right}
.tag-yes{display:inline-block;background:#EAF3DE;color:#3B6D11;border-radius:999px;padding:2px 9px;font-size:12px;font-weight:600;margin-left:4px}
.tag-no{background:var(--line-soft);color:var(--muted)}
.summary-acts{display:grid;grid-template-columns:1fr 2fr;gap:10px;margin-top:16px}

/* alerts */
.alert{border-radius:12px;padding:11px 14px;font-size:14px;margin-bottom:14px}
.alert-err{background:#FCEBEB;color:#791F1F;border:1px solid #F7C1C1}
.alert-ok{background:#EAF3DE;color:#27500A;border:1px solid #C0DD97}

/* misc */
.center{text-align:center}
.muted{color:var(--muted)}
.mt8{margin-top:8px}.mt16{margin-top:16px}
.hide{display:none !important}
.spacer{flex:1}
.foot-note{font-size:12px;color:var(--muted);text-align:center;padding:16px}
@media(max-width:560px){.row2{grid-template-columns:1fr}.pick{grid-template-columns:1fr 1fr}}
/* desktop: roomier centered column for app/form pages; auth/payment (.narrow) stay focused */
@media(min-width:760px){
  .wrap{max-width:680px}
  .nav{max-width:680px}
  main.wrap{padding-top:34px}
}

/* ---- spinners + submit success ---- */
.spin{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;vertical-align:-2px;margin-right:6px;animation:ppspin .7s linear infinite}
.spin-ic{animation:ppspin 1s linear infinite;display:inline-block}
@keyframes ppspin{to{transform:rotate(360deg)}}
.done-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:38px 24px;text-align:center}
.done-ic{width:60px;height:60px;border-radius:50%;background:#EAF3DE;color:#3B6D11;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 14px;animation:pop .42s cubic-bezier(.2,.8,.2,1)}
.done-card h2{font-family:'Fraunces',serif;font-weight:700;margin:0 0 6px;font-size:22px}
.done-card p{color:var(--muted);margin:0}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}

/* ---- dashboard 2-column shell ---- */
.nav-wide{max-width:1040px;padding:0 clamp(16px,4vw,32px)}
.dash{max-width:1040px;margin:0 auto;padding:clamp(18px,3vw,30px) clamp(16px,4vw,32px) 52px;display:grid;gap:clamp(18px,3vw,30px)}
.d-hello{font-family:'Fraunces',serif;font-weight:700;font-size:clamp(1.7rem,1.3rem+1.6vw,2.3rem);margin:0 0 4px;letter-spacing:-.01em}
.d-signed{color:var(--muted);font-size:14px;margin:0 0 16px;word-break:break-all}
.d-plan{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:700;color:var(--soft)}
.d-plan.paid{background:var(--peach);border-color:var(--peach-line);color:var(--terra-dark)}
.d-plan i{font-size:16px}
.d-links{display:flex;flex-direction:column;gap:2px;margin-top:20px}
.d-links a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;text-decoration:none;color:var(--soft);font-weight:500;font-size:15px;transition:background .15s,color .15s}
.d-links a:hover{background:var(--cream);color:var(--ink)}
.d-links i{font-size:19px;color:var(--terra)}
.main-panel{min-width:0}
.main-panel .foot-note{text-align:left;padding:18px 4px 0}
@media(min-width:840px){
  .dash{grid-template-columns:282px 1fr;align-items:start}
  .rail{position:sticky;top:86px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
  .pipe{padding:18px 24px 10px;gap:8px}
  .plabel{font-size:12px}
  .state{padding:36px 32px}
  .state h2{font-size:25px}
  .state p{font-size:15px}
}

/* ---- style reference tiles (brand form) ---- */
.pick .swz-img{width:100%;height:100%;object-fit:cover;display:block}
.pick .swz-cap{position:absolute;left:0;right:0;bottom:0;padding:8px 6px 7px;color:#fff;font-weight:700;font-size:13px;text-align:center;background:linear-gradient(transparent,rgba(0,0,0,.6))}

/* ---- required-field error marking ---- */
.inp.err{border-color:#C0563C !important;background:#FCEEEA}
.contact .inp.err{background:#FCEEEA}
/* ---- read-only (already-submitted) view ---- */
.ro-top{text-align:center;margin:0 0 6px}
.ro-tick{width:42px;height:42px;border-radius:50%;background:#EAF3DE;color:#3B6D11;display:inline-flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:10px}
.ro-top h2{font-family:'Fraunces',serif;font-weight:700;margin:0;font-size:22px}
.ro-sub{color:var(--muted);font-size:14px;margin:5px 0 0}
.ro-list{margin:18px 0 0;padding:0}
.ro-item{padding:11px 2px;border-top:1px solid var(--line)}
.ro-item:first-child{border-top:none}
.ro-item dt{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0 0 3px}
.ro-item dd{margin:0;font-size:15px;color:var(--ink);font-weight:600;line-height:1.4;word-break:break-word}
.ro-note{background:var(--peach);border:1px solid var(--peach-line);border-radius:14px;padding:15px 17px;margin-top:16px;color:var(--terra-dark);font-size:14px;line-height:1.55}
.ro-note a{color:var(--terra-dark);font-weight:700}

/* ---- brand colour chips: empty until chosen ---- */
.color-chip{position:relative}
.color-chip.empty .dab{background:#fff !important;border:1.5px dashed var(--line)}
.color-chip.empty .hex{color:var(--muted)}
.color-chip .clearc{display:none;position:absolute;top:-7px;right:-7px;width:18px;height:18px;border-radius:50%;border:none;background:var(--ink);color:#fff;font-size:11px;line-height:1;cursor:pointer;align-items:center;justify-content:center;padding:0}
.color-chip.set .clearc{display:flex}

/* ---- currency toggle (USD / INR) ---- */
.pp-ccytog{display:inline-flex;background:#F1E9DD;border-radius:999px;padding:3px;gap:2px;vertical-align:middle}
.pp-seg{font:500 13px/1 'DM Sans',system-ui,sans-serif;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:999px;padding:8px 13px;transition:background .15s,color .15s;white-space:nowrap}
.pp-seg.on{background:var(--terra);color:#fff}
.pp-seg:focus-visible{outline:2px solid var(--terra);outline-offset:2px}

/* ---- payment panels ---- */
.pay-pan{margin-top:4px}
.pp-paypal{max-width:340px;margin:14px auto 6px;min-height:50px}
.pp-loading{font-size:13px;color:var(--muted);text-align:center;margin:10px 0 0;display:flex;align-items:center;justify-content:center;gap:8px}
.pay-amt{font-family:'Fraunces',serif;font-weight:700}
.pay-fallback{font-size:13px;color:var(--muted);margin:6px 0 0}

/* ---- dashboard renewal banner ---- */
.renew{margin-top:14px;border:1px solid var(--line);border-radius:14px;padding:12px 14px;font-size:14px;line-height:1.5;display:flex;align-items:flex-start;gap:10px;background:var(--card);text-align:left}
.renew i{font-size:18px;color:var(--green);flex:none;margin-top:1px}
.renew b{font-weight:700}
.renew a{font-weight:600;text-decoration:none}
.renew.due{background:#FFF7E8;border-color:#F0DBA8}
.renew.due i{color:var(--amber)}
