@import url('https://fonts.googleapis.com/css2?family=Alfa+Slab+One&family=Caveat:wght@600;700&family=Nunito:wght@400;700;800;900&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{position:relative;font-family:'Nunito',system-ui,sans-serif;background:#f0e3c8;display:flex;flex-direction:column;height:100dvh;overflow:hidden}
.grain{position:absolute;inset:0;opacity:.06;mix-blend-mode:multiply;pointer-events:none;z-index:60}

/* ============ loading ============ */
#loading{position:absolute;inset:0;z-index:50;background:#1d2a1c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transition:opacity .6s,visibility .6s}
#loading.done{opacity:0;visibility:hidden}
.sign{transform-origin:50% 6px;animation:swing 2.6s ease-in-out infinite}
@keyframes swing{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}
.flash{animation:flash 2.4s ease-in-out infinite}
@keyframes flash{0%,72%,100%{opacity:.15}76%{opacity:1}82%{opacity:.3}88%{opacity:.95}}
.loadbar{width:150px;height:6px;background:#33402f;border-radius:6px;overflow:hidden}
.loadbar>i{display:block;height:100%;width:0;background:#e2a23f;animation:fill 2.2s ease forwards}
@keyframes fill{to{width:100%}}
.load-tag{color:#cdb98a;font-family:'Caveat',cursive;font-size:21px}

/* ============ header ============ */
header{position:relative;z-index:20;background:linear-gradient(#274024,#22381f);color:#f0e3c8;padding:13px 18px 12px;display:flex;align-items:center;gap:11px;border-bottom:1px solid #caa75a;box-shadow:0 2px 0 #182814}
header:after{content:"";position:absolute;bottom:3px;left:12px;right:12px;height:1px;background:#caa75a44}
.h-logo{font-family:'Alfa Slab One',serif;font-size:20px;line-height:1}
.h-sub{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:#bfd0a8;margin-top:2px}
.h-temp{margin-left:auto;text-align:right}
.h-temp b{font-size:21px;font-family:'Alfa Slab One',serif}
.h-temp span{display:block;font-size:9px;color:#bfd0a8;letter-spacing:1px}

/* ============ views + transitions ============ */
.body{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}
.view{display:none;padding:14px 14px 24px}
.view.active{display:block}
.view.enterR{animation:inR .38s cubic-bezier(.25,.9,.3,1) both}
.view.enterL{animation:inL .38s cubic-bezier(.25,.9,.3,1) both}
@keyframes inR{from{opacity:0;transform:translateX(34px)}to{opacity:1;transform:none}}
@keyframes inL{from{opacity:0;transform:translateX(-34px)}to{opacity:1;transform:none}}
.view.leaveL,.view.leaveR{display:block;position:absolute;top:0;left:0;right:0;padding:14px 14px 24px;pointer-events:none}
.view.leaveL{animation:outL .22s ease both}
.view.leaveR{animation:outR .22s ease both}
@keyframes outL{to{opacity:0;transform:translateX(-30px)}}
@keyframes outR{to{opacity:0;transform:translateX(30px)}}
.view.active>*{opacity:0;animation:rise .55s cubic-bezier(.22,.9,.3,1) both}
.view.active>*:nth-child(1){animation-delay:.03s}
.view.active>*:nth-child(2){animation-delay:.08s}
.view.active>*:nth-child(3){animation-delay:.13s}
.view.active>*:nth-child(4){animation-delay:.18s}
.view.active>*:nth-child(5){animation-delay:.23s}
.view.active>*:nth-child(6){animation-delay:.28s}
.view.active>*:nth-child(7){animation-delay:.33s}
.view.active>*:nth-child(n+8){animation-delay:.38s}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ============ hero strip ============ */
.hero{display:flex;align-items:center;gap:10px;background:#fff7e9;border:2px solid #e7d7ae;border-radius:16px;padding:10px 13px;box-shadow:0 1px 0 #00000008,0 8px 18px rgba(70,45,12,.06)}
.hero .hi{font-family:'Caveat',cursive;font-size:20px;color:#241a12;line-height:1.05}
.hero .hi small{display:block;font-family:'Nunito';font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#c8542a;font-weight:800;margin-bottom:3px}

/* Kiro idle / talking */
#kiroHero{animation:bob 4.2s ease-in-out infinite;transform-origin:50% 92%;flex:none}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-.6deg)}50%{transform:translateY(-4px) rotate(.6deg)}}
.k-eyes{transform-box:fill-box;transform-origin:center;animation:blink 5.2s infinite}
@keyframes blink{0%,93.5%,100%{transform:scaleY(1)}96%{transform:scaleY(.08)}}
.k-mouth{transform-box:fill-box;transform-origin:center;transform:scaleY(.14)}
.talking .k-mouth{animation:talkAnim .22s steps(2,end) infinite}
@keyframes talkAnim{0%{transform:scaleY(.14)}50%{transform:scaleY(1)}100%{transform:scaleY(.4)}}
.k-smile{transition:opacity .2s}
.talking .k-smile{opacity:0}
.k-brow{transform-box:fill-box;transform-origin:center;transition:transform .25s}
.talking .k-brow{transform:translateY(-3px)}
.k-stache{transform-box:fill-box;transform-origin:center;animation:twitch 9s ease-in-out infinite}
@keyframes twitch{0%,90%,100%{transform:rotate(0)}93%{transform:rotate(-1.6deg)}96%{transform:rotate(1.1deg)}}
.kbreathe{animation:breathe 4.6s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:translateY(0)}50%{transform:translateY(-2.5px)}}

/* ============ newspaper rubrics ============ */
.rubrics{position:relative;display:flex;gap:2px;margin:15px 2px 2px;border-bottom:2px solid #ddca9e}
.rub{border:none;background:none;font-family:'Nunito';font-weight:800;font-size:11.5px;letter-spacing:1.1px;text-transform:uppercase;color:#a3895a;padding:8px 7px 11px;cursor:pointer;transition:color .25s}
.rub.on{color:#241a12;font-weight:900}
.rub-ink{position:absolute;bottom:-2px;left:0;width:40px;height:3.5px;background:#241a12;border-radius:2px;transition:transform .38s cubic-bezier(.3,1,.3,1),width .38s cubic-bezier(.3,1,.3,1)}

/* ============ feed posts ============ */
.post{background:#fff7e9;border:2px solid #e7d7ae;border-radius:16px;padding:13px;margin-top:13px;animation:rise .5s cubic-bezier(.22,.9,.3,1) both;box-shadow:0 1px 0 #00000008,0 8px 18px rgba(70,45,12,.06)}
.post-head{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.ava{width:38px;height:38px;border-radius:50%;background:#f0e3c8;border:2px solid #241a12;overflow:hidden;flex:none}
.post-head .nm{font-weight:900;color:#241a12;font-size:14px;line-height:1}
.post-head .meta{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:#9c7b40;font-weight:800;margin-top:2px}
.post-head .tag{margin-left:auto;font-size:9.5px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;color:#9c7b40;border:1.5px solid #d8c49a;border-radius:5px;padding:3px 8px}
.post .say{font-family:'Caveat',cursive;font-size:21px;color:#241a12;line-height:1.1;margin-bottom:6px}
.post h4{font-size:16px;color:#241a12;margin:2px 0 8px;line-height:1.25}
.chips{display:flex;gap:7px;margin-bottom:11px;flex-wrap:wrap}
.chip{background:#efe2c4;border-radius:8px;padding:5px 10px;font-size:12px;font-weight:800;color:#5a4422}
.voicebtn{display:flex;align-items:center;gap:10px;width:100%;border:none;cursor:pointer;background:#c8542a;color:#fff7e9;border-radius:12px;padding:11px 13px;font-family:'Nunito';font-weight:800;font-size:14px;box-shadow:0 4px 0 #8f3717;transition:transform .08s,box-shadow .08s}
.voicebtn:active{transform:translateY(3px);box-shadow:0 1px 0 #8f3717}
.play-tri{width:0;height:0;border-left:13px solid #fff7e9;border-top:8px solid transparent;border-bottom:8px solid transparent}
.wave{margin-left:auto;display:flex;gap:3px;align-items:flex-end;height:20px;opacity:.35}
.wave i{width:3px;height:6px;background:#fff7e9;border-radius:2px}
.voicebtn.on .wave{opacity:1}.voicebtn.on .wave i{animation:wv .5s ease-in-out infinite}
.wave i:nth-child(2){animation-delay:.1s}.wave i:nth-child(3){animation-delay:.2s}.wave i:nth-child(4){animation-delay:.3s}.wave i:nth-child(5){animation-delay:.15s}
@keyframes wv{0%,100%{height:5px}50%{height:18px}}

.post.stormpost{background:#7a1d10;border-color:#5a160c;color:#f6e6cf;position:relative;overflow:hidden}
.post.stormpost .nm,.post.stormpost .say{color:#fff7e9}
.post.stormpost .meta{color:#ffb98a}
.post.stormpost .tag{color:#ffce5c;border-color:#ffce5c55}
.post.stormpost .sk{position:absolute;inset:0;background:#fff;opacity:0;animation:lflash 4s ease-in-out infinite;pointer-events:none}
@keyframes lflash{0%,90%,100%{opacity:0}92%{opacity:.45}95%{opacity:0}97%{opacity:.3}}

.match{display:flex;align-items:center;gap:11px;padding:8px 0;border-top:1px solid #ecdcb8}
.match:first-of-type{border-top:none}

/* sport: мач на деня + облог */
.mday-lab{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:900;letter-spacing:2px;color:#9c7b40;text-transform:uppercase;margin:6px 0 9px}
.mday-lab:after{content:"";flex:1;height:1px;background:#ecdcb8}
.duel{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.duel .side{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.duel .badge2{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff7e9;font-weight:900;font-size:12px;border:2px solid #241a12;box-shadow:0 2px 0 #00000026}
.duel .side b{font-size:12.5px;color:#241a12;text-align:center;line-height:1.1}
.duel .mid{flex:none;min-width:78px;text-align:center}
.duel .mid b{font-family:'Alfa Slab One',serif;font-size:19px;color:#c8542a;display:block;line-height:1.1}
.duel .mid span{font-size:8.5px;letter-spacing:1.2px;text-transform:uppercase;color:#9c7b40;font-weight:800}
.fav-tag{display:inline-block;font-size:8.5px;font-weight:900;letter-spacing:1px;color:#8a6420;background:#f2dfae;border:1px solid #d9bc72;border-radius:4px;padding:1px 6px}
.tipslip{display:flex;align-items:center;gap:10px;border:2px dashed #c9ad74;border-radius:10px;padding:7px 12px;margin:10px 0 2px;background:#fbf3df;transform:rotate(-.5deg)}
.tipslip .tl-lab{flex:none;font-size:9px;font-weight:900;letter-spacing:2px;color:#9c7b40;text-transform:uppercase}
.tipslip b{font-family:'Caveat',cursive;font-size:20px;font-weight:700;color:#241a12;line-height:1}
.votebar .q{font-size:11px;font-weight:800;color:#8a6f44;margin:9px 0 6px}
.vote-opts{display:flex;gap:8px}
.vote-opts button{flex:1;border:2px solid #d8c49a;background:#fbf3df;border-radius:10px;padding:7px 6px;font-family:'Nunito';font-weight:800;font-size:12.5px;color:#5a4422;cursor:pointer;transition:.15s}
.vote-opts button span{display:block;font-size:10px;opacity:.7;font-weight:800;margin-top:1px}
.vote-opts button.my{border-color:#c8542a;background:#c8542a;color:#fff7e9}
.scoreline{display:flex;align-items:center;justify-content:center;gap:13px;margin:8px 0 2px}
.scoreline b{font-family:'Alfa Slab One',serif;font-size:29px;color:#241a12}
.scoreline .tn{font-size:13px;font-weight:900;color:#241a12;width:88px}
.seal-win{position:absolute;top:13px;right:13px;font-size:11px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#2f6b2f;border:2.5px solid #2f6b2fa8;border-radius:6px;padding:4px 9px;transform:rotate(8deg)}
.kiro-rec{font-size:11px;font-weight:800;color:#9c7b40;text-align:center;margin-top:8px;border-top:1px solid #ecdcb8;padding-top:8px}
.match .badge{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff7e9;font-weight:900;font-size:11px;flex:none}
.match .mt{flex:1}.match .mt b{font-size:13px;color:#241a12;display:block}.match .mt span{font-size:10px;color:#8a6f44}
.match .mtime{font-weight:900;color:#c8542a;font-size:13px}

/* ============ ЛЕТОПИС ============ */
.memory{position:relative;background:#efddb4;border:2px solid #c9ad74;border-radius:6px;padding:16px 16px 13px;transform:rotate(-1.1deg);margin:16px 4px 6px;box-shadow:0 5px 12px rgba(60,40,10,.13)}
.memory:after{content:"";position:absolute;inset:4px;border:1px solid #b89a6044;border-radius:3px;pointer-events:none}
.tape{position:absolute;top:-9px;left:50%;transform:translateX(-50%) rotate(2deg);width:86px;height:19px;background:#d8c49ad0;border-left:1px dashed #fff9;border-right:1px dashed #fff9}
.mem-tag{font-size:10px;font-weight:900;letter-spacing:2.5px;text-transform:uppercase;color:#8a6f3a}
.mem-row{display:flex;align-items:center;gap:13px;margin:9px 0 7px}
.mem-row b{font-family:'Alfa Slab One',serif;font-size:34px;color:#241a12;line-height:1}
.mem-facts{font-size:11.5px;font-weight:800;color:#6b5328;line-height:1.5}
.mem-facts em{font-style:normal;color:#7a1d10}
.mem-note{font-family:'Caveat',cursive;font-size:19px;color:#4a3522;line-height:1.05;border-top:1px solid #c9ad7466;padding-top:8px}
.lstats{display:flex;gap:9px;margin-top:12px}
.lstats>div{flex:1;background:#243a22;border-radius:12px;padding:9px 6px;text-align:center;box-shadow:inset 0 1px 0 #ffffff14}
.lstats b{display:block;font-family:'Alfa Slab One',serif;font-size:19px;color:#ffce5c;line-height:1.1}
.lstats span{font-size:8.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#bfd0a8}
.led-month{display:flex;align-items:center;gap:10px;margin:18px 2px 8px;font-size:11px;font-weight:900;letter-spacing:3px;color:#9c7b40;text-transform:uppercase}
.led-month:before,.led-month:after{content:"";flex:1;height:1px;background:#d2bd92}
.paper{background:#fff7e9;border:2px solid #e7d7ae;border-radius:16px;padding:2px 14px;box-shadow:0 1px 0 #00000008,0 8px 18px rgba(70,45,12,.06)}
.dayrow{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid #ecdcb8;align-items:center}
.dayrow:last-child{border-bottom:none}
.d-date{width:42px;text-align:center;flex:none}
.d-date b{font-family:'Alfa Slab One',serif;font-size:22px;color:#241a12;display:block;line-height:1}
.d-date span{font-size:9px;font-weight:800;letter-spacing:2px;color:#9c7b40;text-transform:uppercase}
.dayrow.storm .d-date b{color:#7a1d10}
.d-w{flex:none;width:36px;text-align:center}
.d-w svg{width:26px;height:26px;display:block;margin:0 auto}
.d-w span{font-size:9px;font-weight:900;color:#8a6f44}
.d-info{flex:1;min-width:0}
.d-info b{font-size:13px;color:#241a12;display:block;line-height:1.2}
.d-info .dm{font-size:10px;font-weight:800;color:#9c7b40;letter-spacing:.5px;margin:1px 0 3px}
.d-info .cav{font-family:'Caveat',cursive;font-size:18px;color:#4a3522;line-height:1}
.seal{flex:none;font-size:10px;font-weight:900;letter-spacing:1.5px;color:#7a1d10;border:2px solid #7a1d10aa;border-radius:4px;padding:3px 6px;transform:rotate(7deg);align-self:center}
.today-tag{display:inline-block;font-size:8.5px;font-weight:900;letter-spacing:1.5px;color:#fff7e9;background:#c8542a;border-radius:4px;padding:2px 5px;vertical-align:2px;margin-left:5px}

/* ============ КИРО (about) ============ */
.scene{display:block;width:100%;height:auto;border-radius:18px;border:2px solid #16110a;box-shadow:0 10px 24px rgba(40,25,8,.25)}
.kname{text-align:center;margin-top:14px}
.kname h3{font-family:'Alfa Slab One',serif;font-size:27px;color:#241a12;letter-spacing:1px;line-height:1}
.kname .ksub{font-size:10px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:#9c7b40;margin-top:4px}
.kname .kmood{font-family:'Caveat',cursive;font-size:19px;color:#c8542a;margin-top:5px}
.kquote{background:linear-gradient(#274024,#22381f);border-radius:14px;margin-top:13px;padding:13px 16px;text-align:center;font-family:'Caveat',cursive;font-size:23px;color:#ffce5c;box-shadow:inset 0 1px 0 #ffffff18, 0 6px 14px rgba(30,40,20,.25);border:1px solid #1a2a18}
.dossier{margin-top:13px}
.dos-row{display:flex;align-items:baseline;gap:12px;padding:11px 0;border-bottom:1px solid #ecdcb8}
.dos-row:last-child{border-bottom:none}
.dos-row .dl{flex:none;width:108px;font-size:10px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;color:#9c7b40}
.dos-row .dv{flex:1;font-size:13.5px;font-weight:800;color:#241a12;line-height:1.3}
.dos-row.serious .dv{color:#7a1d10}
.kstats{display:flex;gap:9px;margin-top:13px}
.kstats>div{flex:1;background:linear-gradient(#274024,#22381f);border-radius:12px;padding:11px 6px;text-align:center;box-shadow:inset 0 1px 0 #ffffff14}
.kstats b{display:block;font-family:'Alfa Slab One',serif;font-size:21px;color:#ffce5c;line-height:1.15}
.kstats span{font-size:8.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#bfd0a8}
.lampcone{animation:lampf 6s ease-in-out infinite}
@keyframes lampf{0%,100%{opacity:.13}40%{opacity:.19}55%{opacity:.15}70%{opacity:.18}}
.steam{animation:steamUp 3.8s ease-in-out infinite;opacity:0}
.steam.s2{animation-delay:1.3s}
@keyframes steamUp{0%{transform:translateY(4px);opacity:0}30%{opacity:.4}100%{transform:translateY(-10px);opacity:0}}

/* ============ НАСТРОЙКИ ============ */
.set-title{display:flex;align-items:center;gap:10px;margin:17px 2px 8px;font-size:11px;font-weight:900;letter-spacing:3px;color:#9c7b40;text-transform:uppercase}
.set-title:before,.set-title:after{content:"";flex:1;height:1px;background:#d2bd92}
.set-row{display:flex;align-items:center;gap:10px;padding:13px 0;border-bottom:1px solid #ecdcb8}
.set-row:last-child{border-bottom:none}
.set-row .rl{flex:1}.set-row .rl b{font-size:14px;color:#241a12;display:block}.set-row .rl span{font-size:11px;color:#8a6f44}
/* crafted brass switch */
.sw{width:58px;height:30px;border-radius:8px;border:2px solid #241a12;background:#e8d8b4;position:relative;cursor:pointer;transition:background .25s;box-shadow:inset 0 2px 4px rgba(60,40,10,.28);flex:none;padding:0;outline:none}
.sw:before{content:"НЕ";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:'Nunito';font-weight:900;font-size:9px;letter-spacing:1px;color:#9c7b40;transition:.2s}
.sw.on{background:#c8542a;box-shadow:inset 0 2px 4px rgba(80,20,5,.4)}
.sw.on:before{content:"ДА";left:9px;right:auto;color:#fff7e9}
.sw .knob{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:6px;background:linear-gradient(155deg,#e7c06a,#b08d4a 60%,#8a6a33);border:2px solid #241a12;transition:transform .28s cubic-bezier(.34,1.45,.5,1);box-shadow:0 1px 0 rgba(0,0,0,.3), inset 0 1px 0 #ffe9b0aa}
.sw.on .knob{transform:translateX(28px)}
/* ledger inputs */
.led-inp{border:none;background:transparent;border-bottom:2px dotted #b59a64;font-family:'Caveat',cursive;font-size:22px;font-weight:700;color:#241a12;width:138px;text-align:right;padding:0 4px 2px}
.led-inp:focus{outline:none;border-bottom-color:#c8542a}
/* brass segmented */
.seg3{position:relative;display:flex;background:#e8d8b4;border:2px solid #241a12;border-radius:9px;box-shadow:inset 0 2px 4px rgba(60,40,10,.22);overflow:hidden;flex:none}
.seg-win{position:absolute;top:0;left:0;width:0;height:100%;background:linear-gradient(155deg,#dfb35a,#b08d4a);transition:transform .3s cubic-bezier(.34,1.2,.5,1),width .3s cubic-bezier(.34,1.2,.5,1);box-shadow:inset 0 1px 0 #ffe9b0aa}
.seg3 button{position:relative;z-index:1;border:none;background:none;font-family:'Nunito';font-weight:800;font-size:12px;padding:8px 10px;color:#8a6f44;cursor:pointer;transition:color .25s}
.seg3 button.on{color:#241a12;font-weight:900}

/* ============ v4: ритуали — късметче + пошушни ============ */
.rituals{display:flex;gap:10px;margin-top:13px}
.rit{flex:1;position:relative;border:2px dashed #c9ad74;background:#fbf3df;border-radius:10px;padding:9px 11px 8px;cursor:pointer;transform:rotate(-.8deg);transition:transform .18s,background .25s;text-align:left;font-family:'Nunito'}
.rit+.rit{transform:rotate(.9deg)}
.rit:active{transform:scale(.96)}
.rit .rt-lab{font-size:9px;font-weight:900;letter-spacing:1.8px;text-transform:uppercase;color:#9c7b40;display:flex;align-items:center;gap:5px}
.rit .rt-lab svg{width:12px;height:12px;flex:none}
.rit .rt-line{font-family:'Caveat',cursive;font-size:17.5px;font-weight:600;color:#241a12;line-height:1.05;margin-top:4px;min-height:21px}
.rit.open{background:#f4e6bf;transform:rotate(0)}
.rit.open .rt-line{animation:unfold .45s cubic-bezier(.25,1.1,.4,1) both}
@keyframes unfold{from{opacity:0;transform:translateY(5px) scaleY(.6)}to{opacity:1;transform:none}}
.whisper{display:none;margin-top:10px;background:#fbf3df;border:2px dashed #c9ad74;border-radius:10px;padding:11px 12px}
.whisper.open{display:block;animation:rise .4s cubic-bezier(.22,.9,.3,1) both}
.whisper .w-lab{font-size:9px;font-weight:900;letter-spacing:1.8px;text-transform:uppercase;color:#9c7b40;margin-bottom:6px}
.whisper input{width:100%;border:none;background:transparent;border-bottom:2px dotted #b59a64;font-family:'Caveat',cursive;font-size:20px;font-weight:600;color:#241a12;padding:0 2px 3px}
.whisper input:focus{outline:none;border-bottom-color:#c8542a}
.whisper .w-foot{display:flex;align-items:center;gap:9px;margin-top:9px}
.whisper .w-note{flex:1;font-size:10px;font-weight:800;color:#9c7b40}
.whisper button{border:2px solid #241a12;background:linear-gradient(#fff7e9,#f2e4c2);border-radius:9px;padding:6px 13px;font-family:'Nunito';font-weight:900;font-size:12px;color:#241a12;cursor:pointer;box-shadow:0 3px 0 #b89a60;transition:transform .08s,box-shadow .08s}
.whisper button:active{transform:translateY(2px);box-shadow:0 1px 0 #b89a60}

/* ============ v4: реакции-печати ============ */
.reacts{display:flex;gap:7px;margin-top:11px;padding-top:10px;border-top:1px solid #ecdcb8}
.rx{display:flex;align-items:center;gap:5px;border:1.5px solid #d8c49a;background:#fbf3df;border-radius:7px;padding:4px 9px;font-family:'Nunito';font-weight:800;font-size:11.5px;color:#8a6f44;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.rx svg{width:13px;height:13px}
.rx b{font-weight:900}
.rx.my{border-color:#241a12;background:#efe2c4;color:#241a12}
.rx.stamp{animation:stampIn .32s cubic-bezier(.3,1.7,.5,1)}
@keyframes stampIn{0%{transform:scale(.7) rotate(-9deg)}60%{transform:scale(1.13) rotate(3deg)}100%{transform:scale(1) rotate(0)}}
.rx-who{margin-left:auto;align-self:center;font-size:9.5px;font-weight:800;color:#b59a64}

/* ============ v4: питай Киро ============ */
.qa{margin-top:11px;border-top:1px solid #ecdcb8;padding-top:10px}
.qa .q-lab{font-size:9.5px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#9c7b40;margin-bottom:8px}
.qa-item{display:flex;gap:8px;margin-bottom:8px;animation:rise .4s cubic-bezier(.22,.9,.3,1) both}
.qa-item .qa-who{flex:none;width:46px;font-size:10.5px;font-weight:900;color:#8a6f44;text-align:right;padding-top:4px;letter-spacing:.3px}
.qa-item .qa-txt{flex:1;font-size:12.5px;font-weight:700;color:#4a3522;background:#f4e9cd;border-radius:2px 10px 10px 10px;padding:7px 11px;line-height:1.35}
.qa-item.kiro .qa-txt{background:transparent;border:1.5px dashed #c9ad74;font-family:'Caveat',cursive;font-size:18.5px;font-weight:600;color:#241a12;border-radius:10px 2px 10px 10px;line-height:1.1}
.qa-item.kiro .qa-who{color:#c8542a}
.qa-ask{display:flex;gap:8px;margin-top:10px;align-items:flex-end}
.qa-ask input{flex:1;border:none;background:transparent;border-bottom:2px dotted #b59a64;font-family:'Caveat',cursive;font-size:19px;font-weight:600;color:#241a12;padding:0 2px 3px;min-width:0}
.qa-ask input:focus{outline:none;border-bottom-color:#c8542a}
.qa-ask button{flex:none;border:2px solid #241a12;background:linear-gradient(#fff7e9,#f2e4c2);border-radius:9px;padding:6px 12px;font-family:'Nunito';font-weight:900;font-size:12px;color:#241a12;cursor:pointer;box-shadow:0 3px 0 #b89a60;transition:transform .08s,box-shadow .08s}
.qa-ask button:active{transform:translateY(2px);box-shadow:0 1px 0 #b89a60}
.qa-limit{font-size:9.5px;font-weight:800;color:#b59a64;margin-top:7px}

/* ============ v4: Световно (турнирен режим) ============ */
.rubrics{overflow-x:auto;scrollbar-width:none}
.rubrics::-webkit-scrollbar{display:none}
.rub{flex:none}
.wc-day{display:flex;align-items:baseline;gap:8px;margin:4px 0 2px}
.wc-day b{font-family:'Alfa Slab One',serif;font-size:16px;color:#241a12}
.wc-day span{font-size:10px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#9c7b40}
.wcmatch{border-top:1px solid #ecdcb8;padding:10px 0 11px}
.wcmatch:first-of-type{border-top:none}
.wm-row{display:flex;align-items:center;gap:9px}
.wm-flag{flex:none;width:30px;height:21px;border-radius:4px;border:1.5px solid #241a12;overflow:hidden}
.wm-teams{flex:1;font-weight:900;font-size:13.5px;color:#241a12;line-height:1.15}
.wm-teams span{display:block;font-size:9.5px;font-weight:800;color:#9c7b40;letter-spacing:.8px;text-transform:uppercase}
.wm-time{flex:none;font-weight:900;color:#c8542a;font-size:13px}
.wm-foot{display:flex;align-items:center;gap:8px;margin-top:8px}
.wm-slip{flex:1;display:flex;align-items:center;gap:7px;border:1.5px dashed #c9ad74;border-radius:8px;padding:4px 9px;background:#fbf3df;transform:rotate(-.4deg);min-width:0}
.wm-slip .tl-lab{flex:none;font-size:8px;font-weight:900;letter-spacing:1.5px;color:#9c7b40;text-transform:uppercase}
.wm-slip b{font-family:'Caveat',cursive;font-size:17px;font-weight:700;color:#241a12;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wm-votes{flex:none;display:flex;gap:5px}
.wm-votes button{border:1.5px solid #d8c49a;background:#fbf3df;border-radius:7px;padding:4px 8px;font-family:'Nunito';font-weight:900;font-size:10.5px;color:#8a6f44;cursor:pointer;transition:.15s}
.wm-votes button.my{border-color:#c8542a;background:#c8542a;color:#fff7e9}
.wc-board{margin-top:12px;background:linear-gradient(#274024,#22381f);border-radius:12px;padding:10px 13px;box-shadow:inset 0 1px 0 #ffffff14}
.wc-board .wb-lab{font-size:9px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#bfd0a8;margin-bottom:6px}
.wc-board .wb-row{display:flex;align-items:baseline;gap:8px;font-size:12.5px;font-weight:800;color:#e8dcc0;padding:3px 0}
.wc-board .wb-row b{font-family:'Alfa Slab One',serif;font-size:13px;color:#ffce5c;width:16px}
.wc-board .wb-row span{margin-left:auto;font-weight:900;color:#ffce5c}
.wc-board .wb-row.kiro-row{color:#bfd0a8;font-style:italic}

/* ============ v4: летопис — паметни записи, тефтер, сметка ============ */
.canon-mem{position:relative;background:#fff7e9;border:2px solid #c9ad74;border-radius:14px;padding:13px 86px 12px 14px;margin-top:13px;box-shadow:0 1px 0 #00000008,0 8px 18px rgba(70,45,12,.08)}
.canon-mem .cm-tag{font-size:9px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#9c7b40}
.canon-mem h5{font-size:14.5px;color:#241a12;margin:4px 0 3px;line-height:1.2}
.canon-mem .cav{font-family:'Caveat',cursive;font-size:18px;font-weight:600;color:#4a3522;line-height:1.05}
.canon-mem .wax{position:absolute;right:13px;top:50%;transform:translateY(-50%) rotate(9deg);width:60px;height:60px;filter:drop-shadow(0 2px 2px rgba(60,20,5,.3))}
.visitbar{height:7px;border-radius:4px;background:#efe2c4;overflow:hidden;margin-top:4px}
.visitbar i{display:block;height:100%;background:#c8542a;border-radius:4px}
.vrow{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid #ecdcb8}
.vrow:last-child{border-bottom:none}
.vrow .vrank{flex:none;width:26px;font-family:'Alfa Slab One',serif;font-size:19px;color:#b59a64;text-align:center}
.vrow:first-child .vrank{color:#c8542a}
.vrow .vmain{flex:1;min-width:0}
.vrow .vmain b{font-size:13.5px;color:#241a12}
.vrow .vnum{flex:none;font-size:11px;font-weight:900;color:#8a6f44;text-align:right}
.vrow .vnum b{display:block;font-family:'Alfa Slab One',serif;font-size:16px;color:#241a12;line-height:1.1}
.tally-note{font-family:'Caveat',cursive;font-size:18px;color:#8a6f44;text-align:center;margin:9px 4px 0}
.bill{background:#fffdf4;border:1.5px solid #e2d3ab;border-radius:3px 3px 0 0;margin:13px 14px 4px;padding:13px 14px 16px;transform:rotate(.6deg);box-shadow:0 6px 14px rgba(60,40,10,.1);position:relative}
.bill:after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:8px;background:linear-gradient(-45deg,transparent 5px,#fffdf4 0) 0 0/14px 8px repeat-x,linear-gradient(45deg,transparent 5px,#fffdf4 0) 7px 0/14px 8px repeat-x;filter:drop-shadow(0 3px 3px rgba(60,40,10,.08))}
.bill .b-head{text-align:center;font-size:10px;font-weight:900;letter-spacing:3px;text-transform:uppercase;color:#9c7b40;border-bottom:2px dashed #e0d0a6;padding-bottom:8px;margin-bottom:4px}
.bill .b-row{display:flex;align-items:baseline;gap:8px;padding:7px 0;border-bottom:1px dashed #eee0ba;font-size:12px;font-weight:800;color:#5a4422}
.bill .b-row:last-of-type{border-bottom:2px dashed #e0d0a6}
.bill .b-row i{flex:1;border-bottom:2px dotted #e0d0a6;min-width:14px;align-self:flex-end;margin-bottom:3px}
.bill .b-row b{color:#241a12;font-weight:900;text-align:right}
.bill .b-foot{font-family:'Caveat',cursive;font-size:17px;color:#8a6f44;text-align:center;margin-top:9px}

/* ============ v4: Киро таб — настроение, почерпи, решения ============ */
.mood-why{font-family:'Caveat',cursive;font-size:16.5px;color:#9c7b40;margin-top:3px}
.cheers-row{display:flex;gap:10px;margin-top:13px;position:relative}
.cheersbtn{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;border:2px solid #241a12;background:linear-gradient(#fff7e9,#f2e4c2);border-radius:12px;padding:11px;font-family:'Nunito';font-weight:900;font-size:14.5px;color:#241a12;cursor:pointer;box-shadow:0 4px 0 #b89a60;transition:transform .08s,box-shadow .08s}
.cheersbtn:active{transform:translateY(3px);box-shadow:0 1px 0 #b89a60}
.cheersbtn svg{width:19px;height:19px}
.cheers-n{flex:none;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:74px;background:linear-gradient(#274024,#22381f);border-radius:12px;padding:5px 10px;box-shadow:inset 0 1px 0 #ffffff14}
.cheers-n b{font-family:'Alfa Slab One',serif;font-size:19px;color:#ffce5c;line-height:1.1}
.cheers-n span{font-size:8px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#bfd0a8}
.cheers-pop{position:absolute;left:50%;top:-6px;transform:translateX(-50%);font-family:'Caveat',cursive;font-size:20px;font-weight:700;color:#c8542a;white-space:nowrap;pointer-events:none;opacity:0}
.cheers-pop.go{animation:floatUp 1.7s ease both}
@keyframes floatUp{0%{opacity:0;transform:translate(-50%,8px)}18%{opacity:1}100%{opacity:0;transform:translate(-50%,-30px)}}
.ballot-q{font-family:'Caveat',cursive;font-size:21px;font-weight:600;color:#241a12;line-height:1.1;padding:12px 2px 4px}
.ballot-opts{display:flex;flex-direction:column;gap:8px;padding:6px 0 13px}
.ballot-opts button{display:flex;align-items:center;gap:10px;border:2px solid #d8c49a;background:#fbf3df;border-radius:10px;padding:9px 12px;font-family:'Nunito';font-weight:800;font-size:13.5px;color:#5a4422;cursor:pointer;transition:.15s;text-align:left}
.ballot-opts button .bo-n{margin-left:auto;font-size:10.5px;font-weight:800;opacity:.7}
.ballot-opts button.my{border-color:#c8542a;background:#c8542a;color:#fff7e9}
.ballot-foot{font-size:10px;font-weight:800;color:#9c7b40;padding-bottom:12px;border-top:1px dashed #e0d0a6;padding-top:9px}
.canon-row{display:flex;align-items:baseline;gap:10px;padding:11px 0;border-bottom:1px solid #ecdcb8}
.canon-row:last-child{border-bottom:none}
.canon-row .cv{flex:1;font-family:'Caveat',cursive;font-size:19.5px;font-weight:600;color:#241a12;line-height:1.08}
.canon-row .cd{flex:none;font-size:9px;font-weight:900;letter-spacing:1px;text-transform:uppercase;color:#b59a64;text-align:right;line-height:1.5}

/* ============ nav — стегната гравирана табела ============ */
nav{position:relative;z-index:20;display:flex;background:linear-gradient(#274024,#1f3420);padding:9px 10px calc(10px + env(safe-area-inset-bottom));border-top:1px solid #caa75a59;box-shadow:0 -2px 0 #14210f}
.nav-item{flex:1;border:none;background:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;color:#7e9670;font-family:'Nunito';padding:2px 0 0;transition:color .28s}
.nav-item svg{width:22px;height:22px;transition:transform .28s}
.nav-item .lbl{font-size:8.5px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:currentColor;opacity:.85}
.nav-item.active{color:#ffce5c}
.nav-item.active svg{transform:translateY(-1px)}
.navind{position:absolute;top:-1px;left:0;width:34px;height:2.5px;border-radius:0 0 3px 3px;background:#ffce5c;transition:transform .4s cubic-bezier(.3,1.1,.4,1)}
