/* ===================================================================
   SCREENS — home, bonus1, bonus2, bonus3
   =================================================================== */

/* shared bonus header */
.b-head{padding:34px 0 22px;}
.b-title{font-weight:800;font-size:clamp(30px,7vw,44px);letter-spacing:-.02em;line-height:1.05;margin-top:8px;}
.b-lede{margin-top:14px;font-size:17px;color:var(--ink-2);font-weight:400;max-width:34em;text-wrap:pretty;}
.b-lede.big{font-size:clamp(19px,4.5vw,23px);font-weight:500;color:var(--ink);line-height:1.5;}

/* ===================== HOME ===================== */
.home{padding-top:8px;}
.home-hero{padding:46px 0 34px;}
.home-title{font-weight:800;font-size:clamp(34px,8.5vw,56px);letter-spacing:-.03em;line-height:1.02;margin-top:14px;}
.home-sub{margin-top:18px;font-size:18px;line-height:1.55;color:var(--ink-2);max-width:33em;font-weight:400;text-wrap:pretty;}

.card-list{display:flex;flex-direction:column;gap:18px;}
.bonus-card{display:flex;align-items:stretch;gap:20px;text-align:left;width:100%;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;position:relative;overflow:hidden;animation:cardIn .55s var(--ease) both;animation-delay:calc(var(--i)*.09s + .1s);}
@keyframes cardIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.bonus-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease);}
.bonus-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-2);}
.bonus-card:hover::after{transform:scaleY(1);}
.bonus-card:active{transform:translateY(-1px) scale(.995);}
.bonus-card-num{font-weight:800;font-size:30px;color:var(--orange);line-height:1;width:54px;flex:none;padding-top:4px;font-feature-settings:"tnum";letter-spacing:-.02em;}
.bonus-card-body{flex:1;min-width:0;}
.bonus-card-tagrow{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.bonus-card-tag{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--ink-soft);background:var(--orange-tint);padding:4px 11px;border-radius:99px;}
.bonus-card-resume{font-size:12px;font-weight:600;color:#fff;background:var(--orange);padding:4px 11px;border-radius:99px;}
.bonus-card-name{font-weight:800;font-size:24px;letter-spacing:-.015em;line-height:1.15;}
.bonus-card-line{font-weight:500;font-size:16px;color:var(--orange-deep);margin-top:5px;}
.bonus-card-desc{font-size:15px;color:var(--ink-soft);margin-top:9px;line-height:1.5;font-weight:400;text-wrap:pretty;}
.bonus-card-go{flex:none;align-self:center;width:44px;height:44px;border-radius:50%;background:var(--cream);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:background .3s, color .3s, transform .3s var(--ease);}
.bonus-card-go svg{width:20px;height:20px;}
.bonus-card:hover .bonus-card-go{background:var(--ink);color:#fff;transform:translateX(3px);}

/* ===================== BONUS 1 ===================== */
.filterbar{display:flex;gap:9px;overflow-x:auto;padding:4px 2px 14px;margin:0 -22px;padding-left:22px;padding-right:22px;scrollbar-width:none;position:sticky;top:64px;z-index:10;background:linear-gradient(var(--cream) 70%, transparent);}
.filterbar::-webkit-scrollbar{display:none;}
.chip{flex:none;display:inline-flex;align-items:center;gap:8px;font-weight:500;font-size:15px;color:var(--ink-2);background:#fff;border:1px solid var(--line-2);padding:9px 16px;border-radius:99px;transition:all .22s var(--ease);}
.chip:hover{border-color:var(--ink-faint);}
.chip .chip-n{font-size:12px;font-weight:600;color:var(--ink-faint);background:var(--cream);padding:1px 7px;border-radius:99px;min-width:20px;text-align:center;transition:all .22s;}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.chip.on .chip-n{background:rgba(255,255,255,.2);color:#fff;}

.rule-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:6px;}
.rule-card{position:relative;text-align:left;background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-md);padding:18px 18px 18px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm);transition:transform .22s var(--ease), box-shadow .25s, border-color .22s, background .22s;animation:cardIn .45s var(--ease) both;animation-delay:calc(var(--i)*.04s);}
.rule-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--line-2);}
.rule-card:active{transform:translateY(-1px) scale(.99);}
.rule-card.sel{border-color:var(--orange);background:var(--orange-tint);box-shadow:0 4px 16px rgba(232,108,26,.16);}
.rule-cat{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-soft);}
.rule-cat-dot{width:9px;height:9px;border-radius:50%;flex:none;}
.cat-morning{background:#e8a23a;} .cat-evening{background:#7c6fc0;} .cat-habit{background:#3f9a6e;} .cat-recover{background:#d98b8b;} .cat-focus{background:var(--orange);}
.rule-flow{display:flex;flex-direction:column;gap:8px;}
.rule-line{display:flex;gap:9px;align-items:baseline;}
.rule-kw{flex:none;font-weight:800;font-size:11px;letter-spacing:.06em;padding:3px 7px;border-radius:6px;line-height:1;}
.rule-kw.if{background:#efeae2;color:var(--ink-2);}
.rule-kw.then{background:var(--ink);color:#fff;}
.rule-txt{font-size:15.5px;font-weight:500;color:var(--ink);line-height:1.4;text-wrap:pretty;}
.rule-card.sel .rule-kw.if{background:#f2d9bf;color:var(--orange-deep);}
.rule-arrow{color:var(--ink-faint);width:18px;height:18px;margin-left:3px;}
.rule-arrow svg{width:18px;height:18px;}
.rule-check{position:absolute;top:14px;right:14px;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line-2);background:#fff;display:grid;place-items:center;color:transparent;transition:all .22s var(--ease);}
.rule-check svg{width:14px;height:14px;}
.rule-card.sel .rule-check{background:var(--orange);border-color:var(--orange);color:#fff;transform:scale(1.08);}

/* dock */
.dock{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:100%;max-width:680px;padding:0 16px 16px;z-index:30;pointer-events:none;}
.dock>*{pointer-events:auto;}
.dock-empty{background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border:1px dashed var(--line-2);border-radius:var(--r-md);padding:14px 18px;display:flex;align-items:center;gap:11px;font-size:14px;color:var(--ink-soft);box-shadow:var(--shadow-md);}
.dock-empty-ic{flex:none;color:var(--ink-faint);}
.dock-empty-ic svg{width:20px;height:20px;display:block;}
.dock.active{}
.dock.active::before{content:"";position:absolute;inset:0;}
.dock.active>*{}
.dock.active .dock-head,.dock.active .dock-chips,.dock.active .dock-copy{}
.dock.active{display:block;}
.dock.active .dock-head{display:flex;}
.dock-panel{}
.dock.active{}
.dock.active>div,.dock.active>button{}
.dock.active{}
/* actual active panel styling */
.dock.active{padding-bottom:16px;}
.dock-head{display:flex;align-items:center;justify-content:space-between;background:var(--ink);color:#fff;border-radius:var(--r-md) var(--r-md) 0 0;padding:13px 18px;box-shadow:0 -8px 24px rgba(60,40,20,.14);}
.dock-title{font-size:15px;font-weight:500;}
.dock-title b{font-weight:800;color:var(--orange);font-size:18px;}
.dock-clear{font-size:13px;font-weight:500;color:rgba(255,255,255,.7);padding:5px 10px;border-radius:99px;transition:background .2s,color .2s;}
.dock-clear:hover{background:rgba(255,255,255,.12);color:#fff;}
.dock-chips{background:#26211c;max-height:30vh;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;}
.dock-chip{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.07);border-radius:10px;padding:9px 11px;}
.dock-chip .rule-cat-dot{flex:none;}
.dock-chip-txt{flex:1;min-width:0;font-size:13.5px;color:rgba(255,255,255,.9);font-weight:400;line-height:1.35;}
.dock-chip-x{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:rgba(255,255,255,.55);transition:background .2s,color .2s;}
.dock-chip-x svg{width:14px;height:14px;}
.dock-chip-x:hover{background:rgba(255,255,255,.15);color:#fff;}
.dock-copy{width:100%;border-radius:0 0 var(--r-md) var(--r-md);}

/* ===================== BONUS 2 ===================== */
.stepper{display:flex;align-items:center;gap:6px;padding:24px 0 6px;}
.step{display:flex;align-items:center;gap:9px;padding:6px 4px;cursor:default;opacity:.5;transition:opacity .3s;}
.step.on,.step.done{opacity:1;cursor:pointer;}
.step-dot{width:30px;height:30px;border-radius:50%;flex:none;display:grid;place-items:center;font-weight:700;font-size:14px;background:#fff;border:1.5px solid var(--line-2);color:var(--ink-soft);transition:all .3s var(--ease);}
.step.on .step-dot{background:var(--orange);border-color:var(--orange);color:#fff;}
.step.done .step-dot{background:var(--ink);border-color:var(--ink);color:#fff;}
.step-label{font-weight:600;font-size:15px;color:var(--ink-2);}
.step-bar{flex:1;height:2px;background:var(--line-2);border-radius:2px;transition:background .3s;}
.step-bar.done{background:var(--ink);}
.b2-body{min-height:50vh;}

.dump-form{display:flex;gap:10px;margin-top:8px;}
.dump-input{flex:1;font-size:17px;font-weight:400;color:var(--ink);background:var(--paper);border:1.5px solid var(--line-2);border-radius:99px;padding:16px 22px;outline:none;transition:border-color .2s, box-shadow .2s;}
.dump-input::placeholder{color:var(--ink-faint);}
.dump-input:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(232,108,26,.12);}
.dump-add{flex:none;width:56px;height:56px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;box-shadow:0 4px 14px rgba(27,23,20,.2);transition:transform .2s var(--ease), background .2s;}
.dump-add svg{width:22px;height:22px;}
.dump-add:hover{transform:scale(1.06);background:var(--orange);}
.dump-add:active{transform:scale(.95);}

.cloud{display:flex;flex-wrap:wrap;gap:11px;margin-top:26px;align-content:flex-start;}
.cloud-hint{color:var(--ink-faint);font-size:15px;font-weight:400;font-style:italic;width:100%;}
.bubble{display:inline-flex;align-items:center;gap:9px;background:var(--paper);border:1.5px solid var(--line-2);border-radius:99px;padding:11px 16px;font-size:15.5px;font-weight:500;color:var(--ink);box-shadow:var(--shadow-sm);animation:bubbleIn .4s var(--ease) both;animation-delay:calc(var(--i)*.03s);max-width:100%;}
@keyframes bubbleIn{from{opacity:0;transform:scale(.85) translateY(6px);}to{opacity:1;transform:none;}}
.bubble>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:62vw;}
.bubble-x{flex:none;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;color:var(--ink-faint);background:var(--cream);transition:background .2s,color .2s;}
.bubble-x svg{width:13px;height:13px;}
.bubble-x:hover{background:#f1d9d9;color:#c0564f;}
.bubble.tappable{cursor:pointer;transition:transform .2s var(--ease), box-shadow .25s, border-color .2s, background .25s;}
.bubble.tappable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.bubble-q{flex:none;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:var(--ink-faint);border:1.5px dashed var(--line-2);}
.bubble-tag{flex:none;font-size:12px;font-weight:600;padding:3px 9px;border-radius:99px;background:rgba(0,0,0,.05);}

/* category color classes for bubbles/chips */
.bd-worry{--bf:var(--c-worry-fill);--be:var(--c-worry-edge);--bi:var(--c-worry-ink);}
.bd-task{--bf:var(--c-task-fill);--be:var(--c-task-edge);--bi:var(--c-task-ink);}
.bd-goal{--bf:var(--c-goal-fill);--be:var(--c-goal-edge);--bi:var(--c-goal-ink);}
.bd-feel{--bf:var(--c-feel-fill);--be:var(--c-feel-edge);--bi:var(--c-feel-ink);}
.bd-dream{--bf:var(--c-dream-fill);--be:var(--c-dream-edge);--bi:var(--c-dream-ink);}
.bubble.typed{background:var(--bf);border-color:var(--be);color:var(--bi);}
.bubble.typed .bubble-tag{background:rgba(255,255,255,.55);color:var(--bi);}

.legend{display:flex;flex-wrap:wrap;gap:10px 16px;margin:18px 0 4px;padding:14px 18px;background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-md);}
.legend-item{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:500;color:var(--ink-2);}
.legend-dot{width:11px;height:11px;border-radius:50%;flex:none;}
.legend-dot.bd-worry{background:var(--c-worry-ink);} .legend-dot.bd-task{background:var(--c-task-ink);} .legend-dot.bd-goal{background:var(--c-goal-ink);} .legend-dot.bd-feel{background:var(--c-feel-ink);} .legend-dot.bd-dream{background:var(--c-dream-ink);}

.b2-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:30px;padding:18px 0 40px;flex-wrap:wrap;}
.b2-foot.center{justify-content:center;}
.b2-foot-count{font-size:15px;font-weight:500;color:var(--ink-soft);}

/* sheet picker */
.sheet-overlay{position:fixed;inset:0;z-index:60;background:rgba(27,23,20,0);display:flex;align-items:flex-end;justify-content:center;transition:background .25s;}
.sheet-overlay.show{background:rgba(27,23,20,.42);}
.sheet{width:100%;max-width:520px;background:var(--paper);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:14px 18px max(26px,env(safe-area-inset-bottom)) ;box-shadow:var(--shadow-lg);transform:translateY(100%);transition:transform .32s var(--ease);}
.sheet-overlay.show .sheet{transform:none;}
@media(min-width:560px){.sheet-overlay{align-items:center;}.sheet{border-radius:var(--r-xl);margin:0 16px;padding-bottom:22px;}}
.sheet-grip{width:42px;height:5px;border-radius:99px;background:var(--line-2);margin:2px auto 16px;}
.sheet-q{margin-bottom:16px;}
.sheet-q .muted{font-size:13px;}
.sheet-item{font-weight:700;font-size:19px;margin-top:3px;color:var(--ink);line-height:1.3;}
.sheet-opts{display:flex;flex-direction:column;gap:9px;}
.sheet-opt{display:flex;align-items:center;gap:13px;text-align:left;padding:13px 15px;border-radius:var(--r-md);border:1.5px solid var(--line);background:#fff;transition:all .2s var(--ease);}
.sheet-opt:hover{border-color:var(--be);background:var(--bf);}
.sheet-opt.on{border-color:var(--bi);background:var(--bf);}
.sheet-opt-dot{width:16px;height:16px;border-radius:50%;flex:none;background:var(--bi);}
.sheet-opt-label{font-weight:700;font-size:16px;color:var(--ink);}
.sheet-opt.on .sheet-opt-label,.sheet-opt:hover .sheet-opt-label{color:var(--bi);}
.sheet-opt-desc{font-size:13px;color:var(--ink-soft);margin-left:auto;font-weight:400;}

/* manage step */
.manage-cols{display:grid;grid-template-columns:1fr;gap:18px;margin-top:10px;}
@media(min-width:680px){.manage-cols{grid-template-columns:1fr 1fr;align-items:start;}}
.manage-col{background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 18px;}
.manage-col.do{background:#fffaf4;border-color:#f3e2cd;}
.manage-head{display:flex;align-items:center;gap:13px;margin-bottom:16px;}
.manage-ic{width:40px;height:40px;border-radius:12px;flex:none;display:grid;place-items:center;}
.manage-ic.do{background:var(--orange-soft);color:var(--orange-deep);}
.manage-ic.let{background:#eef0f4;color:#5a6480;}
.manage-ic svg{width:22px;height:22px;}
.manage-title{font-weight:800;font-size:18px;letter-spacing:-.01em;}
.manage-note{font-size:13px;color:var(--ink-soft);margin-top:1px;}
.manage-count{margin-left:auto;font-weight:800;font-size:18px;color:var(--ink-faint);}
.manage-empty{font-size:14px;color:var(--ink-faint);font-style:italic;padding:8px 2px;}
.do-card{background:#fff;border:1px solid var(--line);border-left:4px solid var(--bi);border-radius:14px;padding:14px 15px;margin-bottom:10px;box-shadow:var(--shadow-sm);}
.do-card-top{display:flex;align-items:center;gap:9px;margin-bottom:8px;}
.do-tag{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bi);background:var(--bf);padding:3px 9px;border-radius:6px;}
.do-copy{margin-left:auto;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--ink-soft);background:var(--cream);transition:background .2s,color .2s;}
.do-copy svg{width:16px;height:16px;}
.do-copy:hover{background:var(--ink);color:#fff;}
.do-text{font-weight:600;font-size:16px;color:var(--ink);line-height:1.4;text-wrap:pretty;}
.do-verb{font-size:13px;color:var(--ink-soft);margin-top:5px;}
.manage-copyall{width:100%;margin-top:6px;}
.let-card{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:9px;}
.let-dot{width:10px;height:10px;border-radius:50%;flex:none;background:var(--bi);opacity:.7;}
.let-text{font-size:15.5px;font-weight:500;color:var(--ink-2);line-height:1.4;}
.let-ack{margin-top:14px;font-size:15px;font-style:italic;color:var(--ink-soft);line-height:1.55;padding:13px 15px;background:#fff;border-radius:12px;border:1px dashed var(--line-2);text-wrap:pretty;}

/* ===================== BONUS 3 ===================== */
.b3{padding-bottom:40px;}
.b3-stage{padding-top:30px;min-height:62vh;}
.b3-progress{margin-bottom:30px;}
.b3-prog-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;}
.b3-prog-step{font-weight:700;font-size:15px;color:var(--ink);}
.b3-prog-pct{font-size:13px;font-weight:500;color:var(--orange-deep);}
.b3-prog-track{height:6px;background:var(--line);border-radius:99px;overflow:hidden;}
.b3-prog-fill{height:100%;background:var(--orange);border-radius:99px;transition:width .5s var(--ease);}

.q-card{animation:qIn .42s var(--ease) both;}
@keyframes qIn{from{opacity:0;transform:translateX(calc(var(--dir,1)*22px));}to{opacity:1;transform:none;}}
.q-title{font-weight:800;font-size:clamp(24px,5.5vw,34px);letter-spacing:-.02em;line-height:1.18;text-wrap:balance;}
.q-sub{margin-top:10px;font-size:15px;color:var(--ink-soft);font-weight:500;}
.q-opts{display:flex;flex-direction:column;gap:11px;margin-top:26px;}
.q-opt{display:flex;align-items:center;gap:15px;text-align:left;background:var(--paper);border:1.5px solid var(--line-2);border-radius:var(--r-md);padding:17px 20px;box-shadow:var(--shadow-sm);transition:all .2s var(--ease);animation:optIn .4s var(--ease) both;animation-delay:calc(var(--i)*.05s + .08s);}
@keyframes optIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.q-opt:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.q-opt:active{transform:translateY(0) scale(.99);}
.q-opt.on{border-color:var(--orange);background:var(--orange-tint);}
.q-opt-mark{flex:none;width:24px;height:24px;border-radius:50%;border:2px solid var(--line-2);display:grid;place-items:center;transition:all .2s var(--ease);}
.q-opt-mark.box{border-radius:7px;}
.q-opt.on .q-opt-mark{border-color:var(--orange);background:var(--orange);}
.q-opt-mark:not(.box)::after{content:"";width:9px;height:9px;border-radius:50%;background:#fff;transform:scale(0);transition:transform .2s var(--ease);}
.q-opt.on .q-opt-mark:not(.box)::after{transform:scale(1);}
.q-opt-check{color:#fff;opacity:0;transform:scale(.5);transition:all .2s var(--ease);display:grid;place-items:center;}
.q-opt-check svg{width:15px;height:15px;}
.q-opt.on .q-opt-check{opacity:1;transform:scale(1);}
.q-opt-txt{font-weight:500;font-size:17px;color:var(--ink);line-height:1.4;text-wrap:pretty;}
.q-opt.on .q-opt-txt{font-weight:600;}
.q-nav{display:flex;align-items:center;justify-content:space-between;margin-top:26px;gap:14px;}
.q-back{display:inline-flex;align-items:center;gap:7px;font-weight:500;font-size:15px;color:var(--ink-soft);padding:10px 8px;transition:color .2s;}
.q-back:hover{color:var(--ink);}
.q-back svg{width:17px;height:17px;}

/* result */
.result{padding-top:8px;}
.res-reflect{padding:30px 0 8px;animation:screenIn .5s var(--ease) both;}
.reflect-body{margin-top:16px;}
.reflect-p{font-size:clamp(19px,4.4vw,24px);font-weight:500;line-height:1.5;color:var(--ink);margin-bottom:14px;text-wrap:pretty;animation:reflectIn .6s var(--ease) both;animation-delay:calc(var(--i)*.18s + .15s);}
.reflect-p:first-child{font-weight:700;}
@keyframes reflectIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.res-div{display:flex;align-items:center;gap:16px;margin:34px 0 26px;animation:screenIn .5s var(--ease) .6s both;}
.res-div-line{flex:1;height:1px;background:var(--line-2);}
.res-div-txt{font-size:14px;font-weight:600;color:var(--ink-soft);white-space:nowrap;}
.res-acts{display:flex;flex-direction:column;gap:15px;}
.act-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 22px;box-shadow:var(--shadow-sm);border-top:4px solid var(--orange);animation:cardIn .5s var(--ease) both;animation-delay:calc(var(--i,0)*.1s + .7s);}
.act-card.accent-orange{border-top-color:var(--orange);}
.act-card.accent-green{border-top-color:#3f9a6e;}
.act-card.accent-ink{border-top-color:var(--ink);}
.act-top{display:flex;align-items:center;gap:11px;margin-bottom:14px;}
.act-n{font-weight:800;font-size:15px;color:#fff;background:var(--ink);width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:none;}
.act-card.accent-orange .act-n{background:var(--orange);}
.act-card.accent-green .act-n{background:#3f9a6e;}
.act-kind{font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);}
.act-copy{margin-left:auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--ink-soft);background:var(--cream);transition:background .2s,color .2s;}
.act-copy svg{width:17px;height:17px;}
.act-copy:hover{background:var(--ink);color:#fff;}
.act-title{font-weight:800;font-size:22px;letter-spacing:-.015em;line-height:1.25;color:var(--ink);}
.act-meta{display:inline-block;font-size:13px;font-weight:600;color:var(--orange-deep);background:var(--orange-tint);padding:4px 11px;border-radius:99px;margin-top:10px;}
.act-card.accent-green .act-meta{color:#357a59;background:#e8f0e6;}
.act-body{font-size:16px;color:var(--ink-2);line-height:1.55;margin-top:13px;font-weight:400;text-wrap:pretty;}
.act-ifthen{display:flex;flex-direction:column;gap:9px;padding:4px 0 2px;}
.act-why{display:flex;gap:9px;align-items:flex-start;margin-top:16px;padding-top:15px;border-top:1px solid var(--line);font-size:14.5px;color:var(--ink-soft);line-height:1.5;font-weight:400;text-wrap:pretty;}
.act-why-ic{flex:none;color:var(--ink-faint);margin-top:2px;}
.act-why-ic svg{width:16px;height:16px;display:block;}
.res-foot{display:flex;flex-direction:column;gap:11px;margin-top:30px;padding-bottom:30px;}
.res-foot .btn{width:100%;}
@media(min-width:560px){.res-foot{flex-direction:row;}.res-foot .btn{width:auto;flex:1;}}

/* ===================== RESPONSIVE ===================== */
@media(max-width:520px){
  .rule-grid{grid-template-columns:1fr;}
  .bonus-card{padding:22px 18px;gap:14px;}
  .bonus-card-num{width:42px;font-size:26px;}
  .bonus-card-go{display:none;}
  .home-hero{padding:34px 0 26px;}
  .wrap{padding:0 18px;}
  .filterbar{margin:0 -18px;padding-left:18px;padding-right:18px;}
}
@media(min-width:680px){
  .dock-chips{max-height:34vh;}
}

/* ============ BONUS 4 — LIFE RESET BLUEPRINT ============ */
.b4{padding-bottom:60px;}
.b4-chat{
  display:flex;flex-direction:column;gap:14px;
  min-height:38vh;max-height:54vh;
  overflow-y:auto;padding:4px 0 8px;
  scroll-behavior:smooth;
}
.b4-bubble{
  max-width:88%;padding:14px 18px;
  border-radius:18px;font-size:16px;line-height:1.6;
  animation:b4In .3s var(--ease) both;
}
@keyframes b4In{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.b4-bot{
  background:var(--paper);border:1px solid var(--line);
  border-bottom-left-radius:4px;align-self:flex-start;
  box-shadow:var(--shadow-sm);color:var(--ink);
}
.b4-user{
  background:var(--orange);color:#fff;
  border-bottom-right-radius:4px;align-self:flex-end;
  font-weight:500;
}
.b4-typing{display:flex;gap:6px;align-items:center;padding:16px 18px;}
.b4-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ink-faint);
  animation:b4dot 1.1s infinite;
}
.b4-dot:nth-child(2){animation-delay:.18s;}
.b4-dot:nth-child(3){animation-delay:.36s;}
@keyframes b4dot{0%,80%,100%{opacity:.3;transform:scale(.7);}40%{opacity:1;transform:scale(1);}}

.b4-input-wrap{
  margin-top:16px;display:flex;flex-direction:column;gap:10px;
}
.b4-textarea{
  width:100%;padding:14px 18px;
  border:1.5px solid var(--line-2);border-radius:var(--r-md);
  background:var(--paper);color:var(--ink);
  font-family:inherit;font-size:16px;line-height:1.55;
  resize:none;outline:none;
  transition:border-color .2s;
  box-shadow:var(--shadow-sm);
}
.b4-textarea:focus{border-color:var(--orange);}
.b4-textarea::placeholder{color:var(--ink-faint);}
.b4-send{width:100%;padding:15px;font-size:16px;}

.b4-blueprint{
  background:var(--paper);border:1.5px solid var(--line);
  border-radius:var(--r-lg);padding:26px 24px;
  margin-top:8px;box-shadow:var(--shadow-md);
  animation:screenIn .5s var(--ease) both;
}
.b4-blueprint-sub{
  font-size:14px;color:var(--ink-soft);margin-bottom:20px;
}
.b4-blueprint-body,
.b4-blueprint p{
  font-size:15px;line-height:1.75;color:var(--ink-2);
}
.b4-blueprint strong{
  color:var(--ink);font-weight:700;
  display:block;margin-top:18px;margin-bottom:4px;font-size:16px;
}
.b4-blueprint strong:first-child{margin-top:0;}

/* ============ HOME — tiered card layout ============ */

/* Hero card — สีดำ แต่ layout เหมือนเดิมทุกอย่าง */
.bonus-card--hero{
  background: var(--ink);
  border-color: var(--ink);
}
.bonus-card--hero .bonus-card-num{ color: var(--orange); }
.bonus-card--hero .bonus-card-name{ color: #fff; }
.bonus-card--hero .bonus-card-line{ color: var(--orange); }
.bonus-card--hero .bonus-card-desc{ color: rgba(255,255,255,.6); }
.bonus-card--hero .bonus-card-tag{ background: rgba(255,255,255,.1); color: rgba(255,255,255,.7); }
.bonus-card--hero .bonus-card-go{ background: var(--orange); border-color: var(--orange); color: #fff; }
.bonus-card--hero:hover .bonus-card-go{ background: var(--orange-deep); color: #fff; }
.bonus-card--hero::after{ background: var(--orange); }

/* badge "เริ่มจากนี้ก่อน" — อยู่บน tagrow */
.bonus-card-hero-badge{
  display: inline-flex;
  align-items: center;
  background: var(--orange);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 99px;
  padding: 3px 10px;
  margin-right: 6px;
}

/* Small cards — 2 columns */
.card-small-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.bonus-card--small{
  padding: 18px 16px;
  gap: 10px;
}
.bonus-card--small .bonus-card-num{ font-size: 22px; width: 38px; }
.bonus-card--small .bonus-card-name{ font-size: 17px; }
.bonus-card--small .bonus-card-line{ font-size: 13px; }
.bonus-card--small .bonus-card-go{ width: 36px; height: 36px; }
.bonus-card--small .bonus-card-go svg{ width: 15px; height: 15px; }

/* b4 choice options */
.b4-opts{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.b4-opt{
  text-align:left;padding:13px 18px;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;
  background:var(--paper);border:1.5px solid var(--line-2);
  border-radius:var(--r-md);font-size:15px;font-weight:500;
  color:var(--ink);transition:all .18s var(--ease);
  box-shadow:var(--shadow-sm);
}
.b4-opt:hover{border-color:var(--orange);background:var(--orange-tint);transform:translateY(-1px);}
.b4-opt.on{border-color:var(--orange);background:var(--orange-tint);}

/* b4 multi select */
.b4-opts--multi{ display:flex; flex-direction:column; gap:8px; }
.b4-opts--multi .b4-opt{ text-align:left; }
.b4-extra{ margin-top:12px; width:100%; }
.b4-next{ width:100%; margin-top:16px; }

/* b4 reset row */
.b4-reset-row{
  display:flex;justify-content:center;
  margin-top:20px;padding-bottom:40px;
}
.b4-reset-btn{
  font-size:13px;color:var(--ink-faint);
  text-decoration:underline;text-underline-offset:2px;
  background:none;border:none;cursor:pointer;padding:8px;
}
.b4-reset-btn:hover{color:var(--ink-soft);}
