/* Agrowfi PWA — mobile-first, iOS+Android native feel */
*,*::before,*::after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%;overflow-x:hidden;background:#FAFAF6;color:#1A2A24;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}
body[lang="ta"]{font-family:'Noto Sans Tamil','Inter',sans-serif}
body[lang="hi"]{font-family:'Noto Sans Devanagari','Inter',sans-serif}
img,svg,video{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:1rem;border:0;outline:0;background:none;color:inherit}
a{color:#163728;text-decoration:none}
:root{--fg:#163728;--leaf:#7AC74F;--leaf-2:#A0D866;--sun:#FFC845;--terra:#D97441;--ink:#1A2A24;--muted:#6B7A75;--line:#E3E5DC;--bg:#FAFAF6;--white:#fff;--danger:#E14C3C;--good:#10B981;--ios-blue:#007AFF;--shadow:0 4px 12px rgba(22,55,40,.08);--shadow-lg:0 12px 30px rgba(22,55,40,.18)}

/* ========== SPLASH ========== */
.splash{position:fixed;inset:0;background:linear-gradient(160deg,#163728 0%,#0F1F1A 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:999;color:#fff;animation:fadeIn .3s}
.splash-mark{animation:bounce 1.5s ease-in-out infinite}
.splash-word{font-size:2.6rem;font-weight:800;letter-spacing:-.02em}
.splash-sub{color:#A0D866;font-size:.95rem}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ========== LANG ========== */
.lang-screen{position:fixed;inset:0;background:var(--bg);z-index:998;padding:60px 20px 100px;overflow-y:auto;animation:slideUp .35s}
.lang-title{text-align:center;font-size:1.5rem;font-weight:700;margin-bottom:24px}
.lang-title small{display:block;font-weight:500;color:var(--muted);font-size:.85rem;margin-top:.5rem}
.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:480px;margin:0 auto}
.lang-btn{background:var(--white);border:2px solid var(--line);border-radius:16px;padding:18px 12px;text-align:center;font-size:1.4rem;line-height:1.2;transition:all .15s;display:flex;flex-direction:column;gap:6px;align-items:center}
.lang-btn b{font-size:1.05rem;font-weight:700;color:var(--ink)}
.lang-btn span{font-size:.75rem;color:var(--muted)}
.lang-btn:active{transform:scale(.96);border-color:var(--leaf);background:rgba(122,199,79,.08)}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ========== ONBOARDING ========== */
.onboard{position:fixed;inset:0;background:var(--bg);z-index:997;padding:60px 24px 40px;overflow-y:auto;animation:slideUp .3s}
.onboard-back{position:absolute;top:18px;left:18px;width:40px;height:40px;border-radius:50%;background:var(--white);box-shadow:var(--shadow);font-size:1.4rem}
.onboard h2{font-size:1.7rem;font-weight:800;margin:8px 0 4px;color:var(--ink)}
.onboard p{color:var(--muted);margin:0 0 20px}
.onboard label{display:block;font-size:.82rem;font-weight:600;color:var(--muted);margin:14px 0 6px;text-transform:uppercase;letter-spacing:.04em}
.onboard input,.onboard select{width:100%;padding:14px 16px;border-radius:12px;background:var(--white);border:1.5px solid var(--line);font-size:1rem}
.onboard input:focus,.onboard select:focus{border-color:var(--fg)}
.phone-row{display:flex;gap:8px}
.phone-row select{width:110px}
.phone-row input{flex:1}
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.role-card{background:var(--white);border:2px solid var(--line);border-radius:16px;padding:24px 12px;display:flex;flex-direction:column;align-items:center;gap:8px}
.role-card span{font-size:2.4rem}
.role-card b{font-size:.95rem;font-weight:600}
.role-card:active,.role-card.selected{border-color:var(--leaf);background:rgba(122,199,79,.08)}

/* ========== BUTTONS ========== */
.primary-btn{background:var(--leaf);color:var(--fg);font-weight:700;border-radius:12px;padding:14px 22px;font-size:1rem;box-shadow:0 4px 14px rgba(122,199,79,.4);transition:transform .15s}
.primary-btn:active{transform:scale(.97)}
.primary-btn.block{display:block;width:100%;margin-top:14px}
.primary-btn.small{padding:9px 16px;font-size:.9rem}
.secondary-btn{background:var(--white);border:1.5px solid var(--line);color:var(--ink);font-weight:600;border-radius:12px;padding:14px 22px;font-size:1rem}
.secondary-btn.block{display:block;width:100%;margin-top:10px}
.text-btn{background:transparent;color:var(--fg);font-weight:600;padding:8px 4px;font-size:.92rem}
.icon-btn{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;background:transparent;position:relative}
.icon-btn.lg{width:46px;height:46px;font-size:1.4rem}
.icon-btn.primary-icon{background:var(--leaf);color:var(--fg)}
.icon-btn .badge{position:absolute;top:4px;right:4px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:700;border-radius:8px;padding:1px 5px;line-height:1.3}

/* ========== APP SHELL ========== */
.app{padding-top:54px;padding-bottom:78px;min-height:100vh;animation:fadeIn .3s}
.topbar{position:fixed;top:0;left:0;right:0;height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:rgba(250,250,246,.94);backdrop-filter:saturate(180%) blur(12px);z-index:50;border-bottom:1px solid var(--line)}
.topbar-l{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:800}
.topbar-l .logo-mini{font-size:1.4rem}
.topbar-r{display:flex;gap:4px}

.route{padding:8px 14px 14px;animation:fadeIn .35s}
.route-title{font-size:1.5rem;font-weight:800;margin:8px 0 14px}

/* ========== FEED (TikTok style) ========== */
.feed-tabs{display:flex;gap:6px;padding:8px 0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.feed-tabs::-webkit-scrollbar{display:none}
.ftab{padding:8px 14px;border-radius:999px;background:var(--white);color:var(--muted);font-weight:600;font-size:.9rem;border:1.5px solid var(--line);white-space:nowrap}
.ftab.active{background:var(--fg);color:var(--white);border-color:var(--fg)}

.feed-stream{display:flex;flex-direction:column;gap:14px}
.fcard{background:var(--white);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.04)}
.fcard-head{display:flex;align-items:center;gap:10px;padding:12px 14px}
.fcard-head .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#7AC74F,#163728);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.92rem;flex-shrink:0}
.fcard-head .meta b{display:block;font-size:.92rem}
.fcard-head .meta small{color:var(--muted);font-size:.78rem}
.fcard-head .menu{margin-left:auto;color:var(--muted);font-size:1.2rem}
.fcard-media{position:relative;aspect-ratio:1/1.1;background-size:cover;background-position:center}
.fcard-media .play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%)}
.fcard-media .play-overlay span{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.95);color:var(--fg);display:flex;align-items:center;justify-content:center;font-size:1.4rem;padding-left:4px}
.fcard-media .badge-live{position:absolute;top:10px;right:10px;background:var(--danger);color:#fff;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:6px}
.fcard-media .duration{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.7);color:#fff;font-size:.78rem;padding:2px 7px;border-radius:5px}
.fcard-body{padding:12px 14px}
.fcard-body p{margin:0 0 8px;line-height:1.45;font-size:.95rem}
.fcard-actions{display:flex;gap:14px;padding:10px 14px 12px;color:var(--muted);font-size:.9rem;border-top:1px solid var(--line)}
.fcard-actions button{display:flex;align-items:center;gap:4px;font-weight:600;color:var(--muted)}
.fcard-actions .liked{color:var(--danger)}

.fcard.price{background:linear-gradient(135deg,var(--fg) 0%,#1F4938 100%);color:#fff}
.fcard.price .fcard-head .meta b,.fcard.price .fcard-head .meta small{color:rgba(255,255,255,.92)}
.fcard.price .price-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px 14px}
.fcard.price .pg{background:rgba(255,255,255,.08);border-radius:10px;padding:10px}
.fcard.price .pg b{display:block;font-size:1.05rem;color:var(--leaf-2)}
.fcard.price .pg small{color:rgba(255,255,255,.7);font-size:.75rem}

.fcard.alert{border:2px solid var(--sun)}
.fcard.alert .fcard-body p{font-weight:500}

.fcard.weather .weather-row{display:flex;align-items:center;gap:14px;padding:14px}
.fcard.weather .emoji{font-size:3rem}
.fcard.weather .grow{flex:1}
.fcard.weather b{font-size:1.4rem}

.fcard.win{border:2px solid var(--leaf)}
.fcard.win .fcard-head b{color:var(--fg)}

/* ========== CHAT (AI) ========== */
.chat-head{position:sticky;top:54px;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(250,250,246,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);z-index:5}
.chat-head-l{display:flex;align-items:center;gap:10px}
.ai-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#7AC74F,#163728);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.chat-head-l b{font-size:1rem}
.chat-head-l small{display:block;color:var(--good);font-size:.78rem}
.chat-stream{padding:14px 14px 90px;display:flex;flex-direction:column;gap:10px;min-height:calc(100vh - 230px)}
.bubble{max-width:84%;padding:11px 14px;border-radius:18px;font-size:.95rem;line-height:1.5}
.bubble.bot{background:var(--white);border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.bubble.me{background:var(--leaf);color:var(--fg);align-self:flex-end;border-bottom-right-radius:4px;font-weight:500}
.bubble-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.chip{background:rgba(22,55,40,.08);color:var(--fg);font-weight:600;font-size:.82rem;padding:7px 11px;border-radius:999px;border:0}
.chip:active{background:rgba(122,199,79,.2)}
.chat-input{position:fixed;bottom:78px;left:0;right:0;display:flex;gap:6px;padding:10px 12px;background:rgba(250,250,246,.97);backdrop-filter:blur(12px);border-top:1px solid var(--line);align-items:center;z-index:40}
.chat-input input{flex:1;background:var(--white);border:1.5px solid var(--line);border-radius:24px;padding:11px 16px;font-size:.95rem}
.chat-input input:focus{border-color:var(--fg)}
.voice-btn.recording{background:var(--danger);color:#fff;animation:pulseRing 1s infinite}
@keyframes pulseRing{0%,100%{box-shadow:0 0 0 0 rgba(225,76,60,.5)}50%{box-shadow:0 0 0 12px rgba(225,76,60,0)}}

/* ========== CARDS ========== */
.card{background:var(--white);border-radius:16px;padding:16px;margin-bottom:12px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.04)}
.card.alert{border:2px solid var(--sun);background:#FFFBF0}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.card-head h3{font-size:1.05rem;font-weight:700;margin:0}
.card-tag{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.card-tag.good{background:rgba(16,185,129,.12);color:var(--good)}
.card p{margin:0 0 8px;color:var(--muted);font-size:.94rem;line-height:1.5}
.progress{height:6px;background:var(--line);border-radius:99px;overflow:hidden;margin:8px 0 4px}
.progress div{height:100%;background:linear-gradient(90deg,var(--leaf),var(--sun));border-radius:99px}

/* ========== FIELD ========== */
.field-hero{background:linear-gradient(135deg,var(--fg),#0F1F1A);color:#fff;border-radius:18px;padding:14px;margin-bottom:14px;box-shadow:var(--shadow-lg)}
.field-map{position:relative;border-radius:12px;overflow:hidden;margin-bottom:12px}
.field-tag{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.5);color:#fff;font-size:.72rem;padding:4px 9px;border-radius:6px;backdrop-filter:blur(8px)}
.field-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.fs{background:rgba(255,255,255,.08);border-radius:10px;padding:10px 6px;text-align:center;font-size:.78rem;display:flex;flex-direction:column;gap:2px}
.fs b{font-size:1.05rem;color:var(--leaf-2);font-weight:700}
.fs span{color:rgba(255,255,255,.65);font-size:.7rem}
.fs.warning b{color:var(--sun)}
.op-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.op{display:flex;align-items:center;gap:12px}
.op>span{width:38px;height:38px;border-radius:10px;background:var(--bg);display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.op b{display:block;font-size:.92rem;color:var(--ink)}
.op small{color:var(--muted);font-size:.78rem}

/* ========== MARKET ========== */
.ticker-wrap{margin:0 -14px 12px;background:linear-gradient(135deg,var(--fg),#0F1F1A);color:#fff;overflow:hidden}
.ticker-track-app{display:flex;gap:2.5rem;padding:10px 0;white-space:nowrap;animation:tickerScroll 35s linear infinite}
.ticker-track-app span{font-weight:600;font-size:.87rem;display:inline-flex;gap:6px;align-items:center}
.ticker-track-app b{color:var(--leaf-2)}
.ticker-track-app .up{color:var(--leaf)}
.ticker-track-app .down{color:#FF8B7A}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.seg{display:flex;background:var(--white);border-radius:12px;padding:4px;margin-bottom:12px;border:1px solid var(--line);box-shadow:var(--shadow)}
.seg-btn{flex:1;padding:9px 6px;border-radius:9px;font-weight:600;font-size:.87rem;color:var(--muted)}
.seg-btn.active{background:var(--fg);color:#fff}

.listing{padding:0;overflow:hidden}
.listing-img{aspect-ratio:16/8;background-size:cover;background-position:center}
.listing-body{padding:14px}
.listing-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.listing-head b{font-size:1rem}
.tag-live{background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:5px}
.listing-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px;background:var(--bg);border-radius:10px;margin-bottom:10px}
.listing-stats div{text-align:center}
.listing-stats b{display:block;font-size:1.02rem;color:var(--fg)}
.listing-stats small{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}
.listing-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}

.buyer-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.avatar{width:42px;height:42px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem;background:var(--bg);flex-shrink:0}
.buyer-av{background:linear-gradient(135deg,#FFC845,#D97441);color:#fff}
.grow{flex:1;min-width:0}
.grow b{display:block;font-size:.95rem}
.grow small{color:var(--muted);font-size:.76rem}

.fab{position:fixed;right:18px;bottom:96px;width:58px;height:58px;border-radius:50%;background:var(--leaf);color:var(--fg);font-size:1.8rem;font-weight:700;box-shadow:0 8px 24px rgba(122,199,79,.5);display:flex;align-items:center;justify-content:center;z-index:30}
.fab:active{transform:scale(.92)}

/* ========== LEARN ========== */
.cat-row{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:12px}
.cat-row::-webkit-scrollbar{display:none}
.cat{padding:8px 14px;border-radius:999px;background:var(--white);border:1px solid var(--line);font-weight:600;font-size:.87rem;color:var(--muted);white-space:nowrap}
.cat.active{background:var(--fg);color:#fff;border-color:var(--fg)}
.lessons{display:flex;flex-direction:column;gap:12px}
.lesson{background:var(--white);border-radius:14px;overflow:hidden;display:flex;gap:0;box-shadow:var(--shadow)}
.lesson-thumb{flex:0 0 42%;aspect-ratio:1/1;background-size:cover;background-position:center;position:relative}
.lesson-thumb .play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--fg);display:flex;align-items:center;justify-content:center;font-size:1rem;padding-left:3px}
.lesson-thumb .duration{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.75);color:#fff;font-size:.7rem;padding:1px 5px;border-radius:4px}
.lesson-body{padding:12px;display:flex;flex-direction:column;justify-content:center;flex:1}
.lesson-body b{font-size:.92rem;margin-bottom:4px;line-height:1.35;font-weight:600}
.lesson-body small{color:var(--muted);font-size:.76rem}

/* ========== PROFILE ========== */
.profile-hero{background:linear-gradient(160deg,var(--fg),#0F1F1A);color:#fff;border-radius:18px;padding:24px 18px;text-align:center;margin-bottom:14px;box-shadow:var(--shadow-lg)}
.prof-avatar{width:74px;height:74px;border-radius:50%;background:var(--leaf);color:var(--fg);font-size:2rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.profile-hero h2{margin:0;font-size:1.4rem}
.profile-hero p{color:rgba(255,255,255,.75);margin:4px 0 14px;font-size:.88rem}
.trust-score{display:inline-flex;align-items:baseline;gap:6px;background:rgba(122,199,79,.16);border:1px solid rgba(122,199,79,.4);padding:8px 16px;border-radius:14px}
.ts-num{font-size:1.7rem;font-weight:800;color:var(--leaf-2)}
.ts-label{font-size:.78rem;color:rgba(255,255,255,.85);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.profile-hero small{display:block;margin-top:10px;color:rgba(255,255,255,.6);font-size:.78rem}
.profile-hero small a{color:var(--leaf-2);font-weight:600}

.streak{font-size:.85rem;color:var(--terra);font-weight:700}
.big-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}
.big-stats>div{text-align:center;padding:10px 4px;background:var(--bg);border-radius:10px}
.big-stats b{display:block;font-size:1.1rem;color:var(--fg);font-weight:800}
.big-stats small{color:var(--muted);font-size:.72rem;text-transform:uppercase}
.share-btn{margin-top:4px}

.badge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.badge{aspect-ratio:1/1.15;border-radius:12px;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.8rem;text-align:center;border:1px solid var(--line)}
.badge.earned{background:linear-gradient(135deg,#FFFBF0,#FFF2D6);border-color:var(--sun);box-shadow:0 2px 8px rgba(255,200,69,.3)}
.badge.locked{opacity:.5}
.badge small{font-size:.65rem;color:var(--muted);font-weight:600;margin-top:4px;line-height:1.1}

.leader .lrow{display:flex;align-items:center;gap:10px;padding:9px 6px;border-top:1px solid var(--line)}
.leader .lrow:first-child{border-top:0}
.leader .lrow.self{background:rgba(122,199,79,.1);border-radius:8px;border:0;margin:2px 0}
.leader .lrow>span:first-child{font-size:1.2rem;width:24px}
.leader .lrow b{flex:1;font-size:.92rem}
.lr-score{color:var(--fg);font-weight:700}

.setting{display:flex;justify-content:space-between;align-items:center;padding:11px 4px;border-top:1px solid var(--line);font-size:.95rem}
.setting:first-child{border-top:0}
.setting b{color:var(--muted);font-weight:600}

/* ========== UPLOAD ========== */
.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.up-card{background:var(--white);border-radius:16px;padding:24px 14px;text-align:center;border:1.5px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .15s}
.up-card span{font-size:2.4rem}
.up-card b{font-size:.98rem;font-weight:700;color:var(--ink)}
.up-card small{color:var(--muted);font-size:.78rem;line-height:1.3}
.up-card:active{transform:scale(.96);border-color:var(--leaf)}
.upload-note{background:rgba(122,199,79,.1);border-radius:10px;padding:12px;font-size:.85rem;color:var(--muted);text-align:center}

/* ========== NOTIFICATIONS ========== */
.notif{display:flex;gap:12px;align-items:center;padding:14px;background:var(--white);border-radius:14px;margin-bottom:10px;box-shadow:var(--shadow)}
.ni{width:42px;height:42px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.notif b{font-size:.92rem;display:block;margin-bottom:2px}
.notif small{color:var(--muted);font-size:.78rem}

/* ========== BOTTOM NAV ========== */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:72px;background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(14px);border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:center;padding:6px 0 calc(env(safe-area-inset-bottom,0px));z-index:60}
.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;color:var(--muted);font-size:.7rem;transition:color .15s}
.nav-tab span{font-size:1.5rem;transition:transform .2s}
.nav-tab small{font-weight:600}
.nav-tab.active{color:var(--fg)}
.nav-tab.active span{transform:scale(1.15)}
.nav-tab.fab-tab{position:relative}
.nav-tab.fab-tab span{background:var(--leaf);color:var(--fg);width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(122,199,79,.5);margin-top:-22px;font-size:1.5rem}
.nav-tab.fab-tab small{color:var(--fg);font-weight:700;margin-top:2px}

.up-fab{position:fixed;right:18px;bottom:96px;width:54px;height:54px;border-radius:50%;background:var(--white);color:var(--fg);font-size:1.8rem;font-weight:700;box-shadow:var(--shadow-lg);border:1px solid var(--line);z-index:25;display:flex;align-items:center;justify-content:center}

/* ========== BOTTOM SHEET ========== */
.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--white);border-radius:24px 24px 0 0;padding:20px 18px 30px;z-index:200;box-shadow:0 -10px 30px rgba(0,0,0,.18);animation:sheetUp .35s cubic-bezier(.2,.8,.2,1);max-height:84vh;overflow-y:auto}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-handle{width:40px;height:4px;background:var(--line);border-radius:99px;margin:0 auto 14px}
.sheet h3{font-size:1.2rem;margin:0 0 14px}
.sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sheet label{display:block;font-size:.82rem;font-weight:600;color:var(--muted);margin:12px 0 6px;text-transform:uppercase}
.sheet input{width:100%;padding:12px 14px;border-radius:10px;border:1.5px solid var(--line);background:var(--bg)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:150;animation:fadeIn .25s}

/* ========== UTILITY ========== */
[hidden]{display:none !important}
.route[hidden]{display:none !important}

/* small screens / large screens */
@media (min-width:560px){.app,.lang-screen,.onboard{max-width:480px;margin:0 auto;box-shadow:0 0 40px rgba(0,0,0,.1)}.bottom-nav,.chat-input,.fab,.up-fab,.topbar,.chat-head{max-width:480px;left:50% !important;transform:translateX(-50%)}.chat-input{bottom:78px}.fab,.up-fab{left:auto !important;transform:none !important;right:calc(50% - 222px)}}
