:root{
  --paper:#f4efe6;
  --paper-deep:#ece3d4;
  --ink:#2a2520;
  --ink-soft:#6b6155;
  --clay:#b5613e;
  --clay-soft:#d08a63;
  --sage:#6f7d5e;
  --sage-soft:#9aa888;
  --gold:#c19a4b;
  --line:#d8cdb9;
  --card:#fbf8f1;
  --shadow:rgba(60,48,32,.10);
  --blue:#516b8a;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(circle at 12% 6%, rgba(181,97,62,.06), transparent 40%),
    radial-gradient(circle at 88% 96%, rgba(111,125,94,.07), transparent 42%),
    var(--paper);
  color:var(--ink);
  font-family:Georgia,'Iowan Old Style','Palatino Linotype',serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  padding-bottom:96px;
  min-height:100vh;
}
.wrap{max-width:720px;margin:0 auto;padding:0 20px}
em{font-style:italic;color:var(--clay)}
.clay{color:var(--clay)!important}
.mt{margin-top:38px}

/* ===== TOP BAR ===== */
.topbar{position:sticky;top:0;z-index:30;background:rgba(244,239,230,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-in{display:flex;align-items:center;justify-content:space-between;padding:13px 20px}
.brand{display:flex;align-items:center;gap:9px}
.brand-mark{color:var(--gold);font-size:17px}
.brand-txt{font-family:'Helvetica Neue',Arial,sans-serif;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.streak{display:flex;align-items:center;gap:6px;font-family:'Helvetica Neue',Arial,sans-serif;font-weight:700;font-size:14px;color:var(--clay);background:#f3e3d8;padding:5px 12px;border-radius:30px}
.flame{font-size:12px}

/* ===== VIEWS ===== */
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.hero{padding:34px 0 24px}
.hero-date{font-family:'Helvetica Neue',Arial,sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);font-weight:700;margin-bottom:12px}
.hero h1{font-size:clamp(28px,6.5vw,40px);font-weight:400;line-height:1.12;letter-spacing:-.4px;margin-bottom:12px}
.hero-lede{font-size:16px;color:var(--ink-soft);font-style:italic;max-width:520px}

/* ===== PROGRESS ===== */
.progress-card{position:sticky;top:58px;z-index:20;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:13px 17px;margin-bottom:30px;box-shadow:0 6px 22px var(--shadow);display:flex;align-items:center;gap:14px}
.pbar{flex:1;height:9px;background:var(--paper-deep);border-radius:6px;overflow:hidden}
.pfill{height:100%;width:0;background:linear-gradient(90deg,var(--sage),var(--sage-soft));border-radius:6px;transition:width .55s cubic-bezier(.22,1,.36,1)}
.ptext{font-family:'Helvetica Neue',Arial,sans-serif;font-size:12px;font-weight:700;color:var(--sage);white-space:nowrap;letter-spacing:.03em}

/* ===== SECTION HEADERS ===== */
.section-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.section-row h2{font-size:22px;font-weight:400;letter-spacing:-.3px}
.muted-line{color:var(--ink-soft);font-size:14px;font-style:italic;margin-bottom:20px}
.mini-btn{font-family:'Helvetica Neue',Arial,sans-serif;font-size:12.5px;font-weight:600;border:1px solid var(--clay);color:var(--clay);background:transparent;padding:7px 13px;border-radius:30px;cursor:pointer;transition:all .18s ease;white-space:nowrap}
.mini-btn:hover,.mini-btn:active{background:var(--clay);color:#fff}

/* ===== SLOTS ===== */
.slot{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px 20px 18px;margin-bottom:16px;box-shadow:0 4px 18px var(--shadow);transition:border-color .25s ease,background .25s ease}
.slot.done{border-color:var(--sage-soft);background:#f3f5ec}
.slot-top{display:flex;align-items:center;gap:12px;margin-bottom:5px}
.time{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:700;font-size:11.5px;letter-spacing:.05em;color:var(--clay);background:#f3e3d8;padding:5px 11px;border-radius:30px;white-space:nowrap}
.slot.done .time{background:#e2e9d4;color:var(--sage)}
.slot-title{font-size:18px;flex:1}
.slot-edit{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:15px;padding:4px;opacity:.6}
.slot-edit:hover{opacity:1;color:var(--clay)}
.slot-context{color:var(--ink-soft);font-size:14px;margin:2px 0 14px}
.trap{font-family:'Helvetica Neue',Arial,sans-serif;font-size:12.5px;color:var(--clay);background:#fbeee6;border-left:3px solid var(--clay-soft);padding:9px 13px;border-radius:0 8px 8px 0;margin:0 0 14px;line-height:1.5}
.pick-label{font-family:'Helvetica Neue',Arial,sans-serif;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px;font-weight:700}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:'Helvetica Neue',Arial,sans-serif;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 14px;border-radius:30px;cursor:pointer;transition:all .16s ease;user-select:none;display:inline-flex;align-items:center;gap:6px}
.chip:active{transform:scale(.96)}
.chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.chip.sel{color:#fff;font-weight:600;border-color:transparent}
.slot-foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);gap:12px}
.chosen{font-size:13.5px;color:var(--ink-soft);font-style:italic;flex:1}
.chosen b{color:var(--ink);font-style:normal}
.checkbtn{font-family:'Helvetica Neue',Arial,sans-serif;font-size:12.5px;font-weight:600;border:1px solid var(--sage);color:var(--sage);background:transparent;padding:7px 14px;border-radius:30px;cursor:pointer;transition:all .18s ease;white-space:nowrap}
.checkbtn:active{transform:scale(.96)}
.slot.done .checkbtn{background:var(--sage);color:#fff;border-color:var(--sage)}

/* ===== TASKS ===== */
.task{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin-bottom:11px;box-shadow:0 3px 12px var(--shadow);display:flex;align-items:flex-start;gap:13px;transition:opacity .25s ease}
.task.done{opacity:.55}
.task.done .task-name{text-decoration:line-through;color:var(--ink-soft)}
.task-check{width:22px;height:22px;border-radius:7px;border:2px solid var(--sage);background:transparent;cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .18s ease;color:#fff;font-size:13px}
.task.done .task-check{background:var(--sage)}
.task-body{flex:1;min-width:0}
.task-name{font-size:15.5px;word-break:break-word}
.task-meta{display:flex;gap:8px;margin-top:5px;flex-wrap:wrap}
.tag{font-family:'Helvetica Neue',Arial,sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.04em;padding:3px 9px;border-radius:20px;text-transform:uppercase}
.tag.alta{background:#fbe3d8;color:var(--clay)}
.tag.media{background:#f5edd6;color:var(--gold)}
.tag.baja{background:#e6e9df;color:var(--sage)}
.tag.date{background:#e3e9f0;color:var(--blue)}
.task-del{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:16px;opacity:.5;padding:4px;flex-shrink:0}
.task-del:hover{opacity:1;color:var(--clay)}
.empty{text-align:center;color:var(--ink-soft);font-style:italic;font-size:14px;padding:24px 0;opacity:.8}

/* ===== LAYERS (PLAN) ===== */
.layer{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 22px 20px;margin-bottom:15px;box-shadow:0 4px 18px var(--shadow);position:relative;overflow:hidden}
.layer:before{content:attr(data-w);position:absolute;top:-12px;right:8px;font-size:78px;font-weight:700;font-family:'Helvetica Neue',Arial,sans-serif;color:var(--paper-deep);opacity:.6;line-height:1}
.layer-tag{font-family:'Helvetica Neue',Arial,sans-serif;font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--clay);font-weight:700;margin-bottom:7px;position:relative}
.layer.green .layer-tag{color:var(--sage)}
.layer h3{font-size:20px;font-weight:400;margin-bottom:9px;position:relative}
.layer p{color:var(--ink-soft);font-size:15px;position:relative}
.layer .why{margin-top:11px;font-size:13.5px;color:var(--sage);font-style:italic;border-left:3px solid var(--sage-soft);padding-left:12px}

/* ===== CREED ===== */
.creed{background:var(--ink);color:var(--paper);border-radius:18px;padding:28px 26px;margin:32px 0 8px;position:relative;overflow:hidden}
.creed:before{content:"";position:absolute;top:-40px;right:-40px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(193,154,75,.22),transparent 70%)}
.creed h3{font-size:12px;font-family:'Helvetica Neue',Arial,sans-serif;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:700}
.creed p{font-size:16.5px;line-height:1.7;position:relative}
.creed b{color:#fff;font-style:italic;font-weight:400}

/* ===== STATS ===== */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:8px}
.stat-box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 18px;text-align:center;box-shadow:0 3px 14px var(--shadow)}
.stat-n{display:block;font-size:34px;font-weight:400;color:var(--clay);line-height:1;margin-bottom:7px}
.stat-l{font-family:'Helvetica Neue',Arial,sans-serif;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}

/* ===== CHART ===== */
.chart{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px 18px 14px;box-shadow:0 3px 14px var(--shadow);display:flex;align-items:flex-end;gap:5px;height:170px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.bar{width:100%;max-width:22px;background:linear-gradient(180deg,var(--sage-soft),var(--sage));border-radius:5px 5px 0 0;min-height:3px;transition:height .5s ease}
.bar.zero{background:var(--paper-deep)}
.bar-lbl{font-family:'Helvetica Neue',Arial,sans-serif;font-size:9px;color:var(--ink-soft);font-weight:600}

/* ===== EVIDENCE ===== */
.ev{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:17px 19px;margin-bottom:11px;box-shadow:0 3px 12px var(--shadow)}
.ev.warn{border-color:var(--clay-soft);background:#fbeee6}
.ev h4{font-size:15.5px;font-weight:400;margin-bottom:5px;color:var(--clay)}
.ev p{font-size:14px;color:var(--ink-soft)}
.ev .s{color:var(--ink);font-style:italic}

/* ===== SETTINGS ===== */
.set-card{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:20px;margin-bottom:15px;box-shadow:0 3px 14px var(--shadow)}
.set-card h3{font-size:18px;font-weight:400;margin-bottom:6px}
.act-list{display:flex;flex-direction:column;gap:8px;margin:14px 0}
.act-row{display:flex;align-items:center;gap:11px;padding:9px 12px;background:#fff;border:1px solid var(--line);border-radius:10px}
.act-row .dot{width:13px;height:13px;border-radius:50%;flex-shrink:0}
.act-row .nm{flex:1;font-family:'Helvetica Neue',Arial,sans-serif;font-size:14px}
.act-row .rm{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:16px;opacity:.5;padding:2px 6px}
.act-row .rm:hover{opacity:1;color:var(--clay)}
.inline-add{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline-add input[type=text]{flex:1;min-width:140px}
input[type=text],.full-input{font-family:'Helvetica Neue',Arial,sans-serif;font-size:14px;border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px 13px;color:var(--ink);outline:none;width:100%}
input[type=text]:focus,.full-input:focus{border-color:var(--clay-soft)}
input[type=color]{width:44px;height:42px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;padding:3px}
.btn-row{display:flex;gap:10px;margin:14px 0 12px;flex-wrap:wrap}
.ghost-btn{flex:1;min-width:130px;font-family:'Helvetica Neue',Arial,sans-serif;font-size:13.5px;font-weight:600;border:1px solid var(--ink-soft);color:var(--ink);background:transparent;padding:11px;border-radius:10px;cursor:pointer;transition:all .18s ease}
.ghost-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.danger-btn{width:100%;font-family:'Helvetica Neue',Arial,sans-serif;font-size:13px;font-weight:600;border:1px solid var(--clay);color:var(--clay);background:transparent;padding:11px;border-radius:10px;cursor:pointer;transition:all .18s ease}
.danger-btn:hover{background:var(--clay);color:#fff}
.footnote{text-align:center;font-style:italic;color:var(--ink-soft);font-size:14px;margin:30px 0 10px;padding:0 20px}

/* ===== TABBAR ===== */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:40;background:rgba(251,248,241,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);display:flex;padding:8px 8px calc(8px + env(safe-area-inset-bottom));max-width:720px;margin:0 auto}
.tab{flex:1;background:none;border:none;cursor:pointer;font-family:'Helvetica Neue',Arial,sans-serif;font-size:11px;font-weight:600;color:var(--ink-soft);padding:7px 4px;display:flex;flex-direction:column;align-items:center;gap:4px;border-radius:12px;transition:color .2s ease}
.tab .ico{font-size:19px;line-height:1}
.tab.active{color:var(--clay)}

/* ===== MODAL ===== */
.modal-bg{position:fixed;inset:0;background:rgba(42,37,32,.55);backdrop-filter:blur(3px);z-index:60;display:none;align-items:flex-end;justify-content:center;padding:0}
.modal-bg.show{display:flex}
.modal{background:var(--paper);border-radius:22px 22px 0 0;padding:26px 22px calc(26px + env(safe-area-inset-bottom));width:100%;max-width:720px;max-height:86vh;overflow-y:auto;animation:slideup .3s cubic-bezier(.22,1,.36,1)}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.modal h3{font-size:21px;font-weight:400;margin-bottom:18px}
.field{margin-bottom:15px}
.field label{display:block;font-family:'Helvetica Neue',Arial,sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:7px}
.seg{display:flex;gap:7px}
.seg button{flex:1;font-family:'Helvetica Neue',Arial,sans-serif;font-size:13px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--ink);padding:10px;border-radius:10px;cursor:pointer;transition:all .16s ease}
.seg button.on{background:var(--clay);color:#fff;border-color:var(--clay)}
.modal-actions{display:flex;gap:10px;margin-top:22px}
.modal-actions button{flex:1;font-family:'Helvetica Neue',Arial,sans-serif;font-size:14px;font-weight:600;padding:13px;border-radius:12px;cursor:pointer;border:none}
.btn-cancel{background:transparent;border:1px solid var(--line)!important;color:var(--ink-soft)}
.btn-save{background:var(--clay);color:#fff}
.chk-row{display:flex;align-items:center;gap:10px;margin-top:8px}
.chk-row input{width:18px;height:18px;accent-color:var(--clay)}
.chk-row label{font-family:'Helvetica Neue',Arial,sans-serif;font-size:13px;color:var(--ink);text-transform:none;letter-spacing:0;font-weight:400;margin:0}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--paper);font-family:'Helvetica Neue',Arial,sans-serif;font-size:13.5px;font-weight:600;padding:12px 20px;border-radius:30px;z-index:80;opacity:0;pointer-events:none;transition:all .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.25);white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:480px){
  .slot-foot{flex-wrap:wrap}
  .stat-grid{gap:10px}
}
