/* ===================================================================
   Nepal Marketplace — mobile-first plain CSS
   =================================================================== */
:root{
  /* Warm, trustworthy, distinctly Nepali — deep emerald + saffron on soft cream */
  --green:#0b6e50; --green-d:#084e39; --emerald-l:#13a06e;
  --saffron:#f59e0b; --saffron-d:#d97f06;
  --crimson:#e02b54; --ink:#1f2a37; --muted:#6f7785;
  --bg:#faf6ee; --card:#ffffff; --line:#ece4d6; --gold:#e0a006;
  --radius:16px; --radius-sm:10px; --radius-lg:24px;
  --shadow-sm:0 1px 2px rgba(31,42,55,.06);
  --shadow:0 4px 16px -4px rgba(31,42,55,.10),0 2px 6px -2px rgba(31,42,55,.06);
  --shadow-lg:0 22px 48px -16px rgba(20,40,33,.28),0 6px 16px -8px rgba(31,42,55,.12);
  --maxw:1140px;
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --font-serif:'Fraunces','Mukta',Georgia,'Times New Roman',serif;
  --font-sans:'Mukta','Segoe UI',system-ui,-apple-system,'Noto Sans Devanagari',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-sans);color:var(--ink);background:var(--bg);line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--green-d);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.25;margin:.2em 0 .5em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.center{text-align:center}
.mt{margin-top:1rem}.mb{margin-bottom:1rem}.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.spacer{flex:1}

/* Buttons */
.btn,button.btn,a.btn{display:inline-flex;align-items:center;gap:.4rem;justify-content:center;
  background:var(--green);color:#fff;border:0;border-radius:var(--radius-sm);padding:.6rem 1rem;
  font-size:1rem;cursor:pointer;font-weight:600;transition:background .15s;text-decoration:none}
.btn:hover{background:var(--green-d);text-decoration:none}
.btn-block{display:flex;width:100%}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:#f0f2f5}
.btn-danger{background:var(--crimson)}.btn-danger:hover{background:#b30f30}
.btn-gold{background:var(--gold);color:#3a2a00}
.btn-sm{padding:.35rem .65rem;font-size:.85rem}
.linklike{background:none;border:0;color:var(--ink);cursor:pointer;font:inherit;padding:0}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:.45rem;font-weight:800;font-size:1.15rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{font-size:1.4rem}
.header-search{display:flex;flex:1;min-width:160px;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.header-search input{border:0;padding:.55rem .9rem;flex:1;font-size:.95rem;outline:none;background:transparent}
.header-search button{border:0;background:transparent;padding:0 .8rem;cursor:pointer;font-size:1rem}
.header-nav{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}
.nav-link{padding:.45rem .6rem;border-radius:8px;color:var(--ink);font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:.3rem}
.nav-link:hover{background:#f0f2f5;text-decoration:none}
.btn-post{background:var(--green);color:#fff}.btn-post:hover{background:var(--green-d)}
.nav-icon{position:relative;font-size:1.1rem}
.badge{position:absolute;top:-2px;right:-4px;background:var(--crimson);color:#fff;border-radius:999px;font-size:.65rem;padding:0 .3rem;min-width:16px;text-align:center}
.avatar-xs{width:24px;height:24px;border-radius:50%;object-fit:cover;vertical-align:middle}
.lang-toggle{border:1px solid var(--line)}
.menu{position:relative}
.menu summary{list-style:none;cursor:pointer}
.menu summary::-webkit-details-marker{display:none}
.menu-pop{position:absolute;right:0;top:120%;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);min-width:180px;padding:.35rem;display:flex;flex-direction:column;z-index:60}
.menu-pop a,.menu-pop button{padding:.55rem .7rem;border-radius:7px;text-align:left;color:var(--ink)}
.menu-pop a:hover,.menu-pop button:hover{background:#f0f2f5;text-decoration:none}
.menu-pop form{margin:0}

/* Flash */
.flash{margin:.8rem 0;padding:.7rem 1rem;border-radius:10px;font-weight:600}
.flash-success{background:#e7f6ee;color:#0b5e3b;border:1px solid #bfe6cf}
.flash-error{background:#fdecef;color:#9b1c31;border:1px solid #f5c2cc}
.flash-info{background:#eaf1fb;color:#1e40af;border:1px solid #c7d8f5}

/* Hero */
.hero{background:linear-gradient(135deg,var(--green),var(--green-d));color:#fff;padding:2.4rem 0}
.hero h1{font-size:1.9rem;margin:0 0 .4rem}
.hero p{opacity:.92;margin:0 0 1.2rem;max-width:560px}
.hero .toggle-buy-rent{display:inline-flex;background:rgba(255,255,255,.15);border-radius:999px;padding:.25rem;margin-bottom:1rem}
.hero .toggle-buy-rent a{color:#fff;padding:.4rem 1.1rem;border-radius:999px;font-weight:700}
.hero .toggle-buy-rent a.active{background:#fff;color:var(--green-d)}
.hero-search{background:#fff;border-radius:var(--radius);padding:.5rem;display:flex;gap:.5rem;box-shadow:var(--shadow-lg);max-width:620px}
.hero-search input{flex:1;border:0;padding:.7rem;font-size:1rem;outline:none}

/* Sections */
.section{padding:1.6rem 0}
.section h2{font-size:1.3rem;margin-bottom:1rem}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}

/* Category chips */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.cat-tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;text-align:center;color:var(--ink);font-weight:700;box-shadow:var(--shadow)}
.cat-tile:hover{box-shadow:var(--shadow-lg);text-decoration:none;transform:translateY(-1px)}
.cat-tile .ic{font-size:1.8rem;display:block;margin-bottom:.3rem}
.cat-tile small{display:block;font-weight:500;color:var(--muted)}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-lg)}
.card-media{position:relative;aspect-ratio:4/3;background:#eef1f4;display:block}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-noimg{display:flex;align-items:center;justify-content:center;height:100%;font-size:2rem;color:#aab}
.card-body{padding:.6rem .7rem;display:flex;flex-direction:column;gap:.2rem}
.card-title{font-weight:700;color:var(--ink);font-size:.98rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-price{color:var(--green-d);font-weight:800}
.tag{position:absolute;font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;color:#fff}
.tag-kind{top:.5rem;left:.5rem;background:rgba(15,122,77,.92)}
.tag-rent{background:rgba(220,20,60,.92)}
.tag-featured{top:.5rem;right:.5rem;background:var(--gold);color:#3a2a00}
.sold-overlay{position:absolute;inset:0;background:rgba(26,34,48,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;letter-spacing:.05em}
.fav-btn{position:absolute;top:.4rem;right:.4rem;background:rgba(255,255,255,.92);border:0;border-radius:50%;width:32px;height:32px;cursor:pointer;color:#cbd2db;font-size:1rem;box-shadow:var(--shadow)}
.card-media + .card-body + .fav-btn,.card .fav-btn{top:.4rem}
.fav-btn.is-fav{color:var(--crimson)}
.verified{color:var(--green)}

/* Layout split (browse / listing) */
.split{display:grid;grid-template-columns:1fr;gap:1.2rem}
.filters{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:.5rem .85rem}
.filters h3{margin-top:0}
.filter-panel>summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-weight:700;padding:.55rem .1rem}
.filter-panel>summary::-webkit-details-marker{display:none}
.filter-panel>summary::after{content:"▾";color:var(--muted);font-size:.8rem}
.filter-panel[open]>summary::after{content:"▴"}
.filter-body{padding-top:.4rem}
.filters .field{margin-bottom:.6rem}
.filters label{font-size:.85rem;margin-bottom:.2rem}
.filters .address-grid{gap:0 .55rem}
.price-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
@media(min-width:900px){
  .filters{position:sticky;top:80px;padding:1rem}
  .filter-panel>summary{display:none}
  .filter-panel>.filter-body{display:block!important;padding-top:0}
}

/* Forms */
.field{margin-bottom:.9rem;position:relative}
.field label{display:block;font-weight:600;margin-bottom:.3rem;font-size:.92rem}
input[type=text],input[type=search],input[type=password],input[type=number],input[type=email],input[type=date],input[type=tel],select,textarea{
  width:100%;padding:.6rem .7rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:1rem;background:#fff;outline:none;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(15,122,77,.12)}
textarea{min-height:110px;resize:vertical}
.checkbox{display:flex;align-items:center;gap:.5rem;font-weight:500}
.checkbox input{width:auto}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}
.form-narrow{max-width:440px;margin:1.5rem auto}
.grid2{display:grid;grid-template-columns:1fr;gap:0 1rem}
.errors{background:#fdecef;border:1px solid #f5c2cc;color:#9b1c31;border-radius:10px;padding:.6rem .9rem;margin-bottom:1rem}
.errors li{margin-left:1rem}
.help{font-size:.82rem;color:var(--muted);margin-top:.25rem}
.divider{display:flex;align-items:center;gap:.7rem;color:var(--muted);margin:1rem 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}

/* Combobox */
.combo{position:relative}
.combo-list{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 10px 10px;max-height:240px;overflow:auto;z-index:30;box-shadow:var(--shadow-lg)}
.combo-list div{padding:.5rem .7rem;cursor:pointer}
.combo-list div:hover,.combo-list div.active{background:#eef6f1}
.address-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 .8rem}

/* Pills / segmented */
.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.seg a,.seg button{padding:.45rem 1rem;color:var(--ink);font-weight:600;border:0;background:transparent;cursor:pointer}
.seg a.active,.seg button.active{background:var(--green);color:#fff}

/* Listing detail */
.listing-wrap{display:grid;grid-template-columns:1fr;gap:1.2rem;margin:1.2rem 0}
.gallery-main{aspect-ratio:16/10;background:#eef1f4;border-radius:var(--radius);overflow:hidden}
.gallery-main img,.gallery-main video{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}
.gallery-thumbs img{width:72px;height:56px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent}
.gallery-thumbs img.active{border-color:var(--green)}
.price-big{font-size:1.6rem;font-weight:800;color:var(--green-d)}
.attr-table{width:100%;border-collapse:collapse;margin:.5rem 0}
.attr-table td{padding:.45rem .2rem;border-bottom:1px solid var(--line);font-size:.95rem}
.attr-table td:first-child{color:var(--muted);width:45%}
.seller-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);position:sticky;top:80px}
.safety{background:#fff8e6;border:1px solid #f3e1a8;border-radius:10px;padding:.7rem .9rem;font-size:.9rem;margin-top:.8rem}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.badge-status{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.78rem;font-weight:700}
.st-active{background:#e7f6ee;color:#0b5e3b}.st-pending_approval{background:#fff3d6;color:#8a5a00}
.st-sold{background:#e9ecf2;color:#444}.st-rejected,.st-disabled{background:#fdecef;color:#9b1c31}
.st-pending_payment,.st-draft,.st-expired{background:#eef1f4;color:#555}

/* Map */
.map{height:280px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
#sell-map{height:300px}

/* Chat */
.chat-layout{display:grid;grid-template-columns:1fr;gap:1rem;margin:1rem 0}
.conv-list{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.conv-item{display:flex;gap:.6rem;padding:.7rem;border-bottom:1px solid var(--line);color:var(--ink);align-items:center}
.conv-item:hover{background:#f7f9fb;text-decoration:none}
.conv-item .thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;background:#eef1f4;flex-shrink:0}
.conv-unread{margin-left:auto;background:var(--crimson);color:#fff;border-radius:999px;font-size:.7rem;padding:0 .4rem}
.thread{display:flex;flex-direction:column;height:70vh;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.thread-head{padding:.7rem 1rem;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.6rem}
.thread-body{flex:1;overflow:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem;background:#f7f9fb}
.msg{max-width:78%;padding:.5rem .75rem;border-radius:14px;background:#fff;border:1px solid var(--line);align-self:flex-start;word-wrap:break-word}
.msg.mine{align-self:flex-end;background:var(--green);color:#fff;border-color:var(--green)}
.msg img{border-radius:10px;margin:-.1rem}
.msg .time{font-size:.68rem;opacity:.7;margin-top:.2rem}
.thread-input{display:flex;gap:.5rem;padding:.6rem;border-top:1px solid var(--line);align-items:center}
.thread-input input[type=text]{flex:1}

/* Admin */
.admin-layout{display:grid;grid-template-columns:1fr;gap:1rem;margin:1rem 0}
.admin-side{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:.5rem}
.admin-side a{display:block;padding:.55rem .7rem;border-radius:8px;color:var(--ink);font-weight:600}
.admin-side a:hover,.admin-side a.active{background:#eef6f1;text-decoration:none}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.stat .n{font-size:1.6rem;font-weight:800;color:var(--green-d)}
.table-wrap{overflow:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
table.data{width:100%;border-collapse:collapse;font-size:.9rem}
table.data th,table.data td{padding:.55rem .6rem;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
table.data th{background:#f7f9fb;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
table.data tr:hover{background:#fafbfc}
.inline-form{display:inline}

/* Pager */
.pager{display:flex;gap:.3rem;justify-content:center;margin:1.4rem 0}
.pager a{padding:.45rem .75rem;border:1px solid var(--line);border-radius:8px;color:var(--ink);background:#fff}
.pager a.active{background:var(--green);color:#fff;border-color:var(--green)}

/* Steps (onboarding) */
.steps{display:flex;flex-direction:column;gap:.8rem}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.step.done{border-color:#bfe6cf;background:#f3fbf6}
.step h3{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem}
.pill-ok{background:var(--green);color:#fff;border-radius:999px;font-size:.72rem;padding:.1rem .5rem}

/* Footer */
.site-footer{background:#0c1322;color:#c5ccd6;margin-top:2rem;padding:1.6rem 0 .8rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:1.2rem}
.site-footer h4{color:#fff;margin:.2rem 0 .5rem}
.site-footer a{display:block;color:#c5ccd6;padding:.15rem 0}
.site-footer .brand-name{color:#fff}
.footer-bottom{border-top:1px solid #20293c;margin-top:1rem;padding-top:.8rem;font-size:.85rem}

/* Responsive */
@media(min-width:640px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .grid{grid-template-columns:repeat(3,1fr)}
  .grid2{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2.3rem}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
}
@media(min-width:900px){
  .cat-grid{grid-template-columns:repeat(6,1fr)}
  .grid{grid-template-columns:repeat(4,1fr)}
  .split{grid-template-columns:260px 1fr}
  .listing-wrap{grid-template-columns:1.7fr 1fr}
  .chat-layout{grid-template-columns:320px 1fr}
  .admin-layout{grid-template-columns:210px 1fr}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
}

/* ===================================================================
   MOBILE COMPATIBILITY — all phones (≤899px). Desktop (≥900px) untouched.
   =================================================================== */
.mobile-tabbar{display:none}

@media (max-width:899px){
  :root{ --tabbar-h:58px; }

  /* Safe-area aware, decluttered header (navigation moves to bottom bar) */
  .site-header{padding-top:env(safe-area-inset-top)}
  .header-row{gap:.45rem .4rem;padding:.5rem 14px}
  .brand{order:1}
  .brand-name{font-size:1.05rem}
  .header-nav{order:2;margin-left:auto;gap:.25rem}
  .header-nav > *:not(.lang-toggle){display:none}
  .header-search{order:3;flex-basis:100%;min-width:0}
  .lang-toggle{font-size:.85rem;padding:.4rem .6rem}

  /* Make room for the fixed bottom bar */
  body{padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 8px)}

  /* App-style bottom navigation */
  .mobile-tabbar{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:70;
    background:#fff;border-top:1px solid var(--line);
    box-shadow:0 -2px 12px rgba(16,24,40,.08);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .mobile-tabbar a{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    min-height:var(--tabbar-h);padding:.3rem 0;color:var(--muted);font-size:.66rem;font-weight:600;
    text-decoration:none;position:relative;
  }
  .mobile-tabbar a:hover{text-decoration:none}
  .mobile-tabbar a .ic{font-size:1.3rem;line-height:1;position:relative}
  .mobile-tabbar a.active{color:var(--green)}
  .mobile-tabbar .tab-post .ic{
    width:48px;height:48px;margin-top:-20px;border-radius:50%;
    background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:1.7rem;box-shadow:0 4px 12px rgba(15,122,77,.45);
  }
  .mobile-tabbar .badge{top:-4px;right:-8px}

  /* Comfortable touch targets + no horizontal overflow on any width */
  .btn,.nav-link{min-height:44px}
  .btn-sm{min-height:36px}
  .card-title,.price-big,h1,h2,.msg{overflow-wrap:anywhere}
  .listing-wrap,.split,.chat-layout,.admin-layout{gap:1rem}
}

/* Large phones / phablets: keep 2-up cards (don't jump to 3) just under tablet */
@media (min-width:640px) and (max-width:759px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
}

/* Small phones (≤380px) */
@media (max-width:380px){
  .container{padding:0 12px}
  .brand-name{font-size:.98rem}
  .hero{padding:1.8rem 0}
  .hero h1{font-size:1.5rem}
  .grid{gap:.55rem}
  .card-title{font-size:.9rem}
  .cat-grid{gap:.5rem}
  .cat-tile{padding:.75rem .4rem}
  .price-big{font-size:1.35rem}
  .mobile-tabbar a{font-size:.6rem}
}

/* Very small (≤330px: iPhone SE 1, older Androids) */
@media (max-width:330px){
  .grid{gap:.45rem}
  .btn{font-size:.92rem}
  .header-search input{padding:.5rem .6rem;font-size:.9rem}
}

/* "Why" trust section — compact icon-left rows on mobile, 3-up cards on wider screens */
.why-section{background:#fff;border-top:1px solid var(--line)}
.why-grid{display:flex;flex-direction:column;gap:.55rem;margin-top:.85rem}
.why-card{display:flex;gap:.7rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.7rem .85rem}
.why-card .why-ic{font-size:1.45rem;line-height:1;flex-shrink:0}
.why-card h3{margin:0 0 .12rem;font-size:1rem}
.why-card p{margin:0;font-size:.86rem;line-height:1.35}
@media (min-width:640px){
  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
  .why-card{flex-direction:column;padding:1.1rem}
  .why-card .why-ic{font-size:1.9rem}
}

/* Phone footer: link groups two-in-a-row (brand spans the top) */
@media (max-width:639px){
  .site-footer{padding:1.4rem 0 .8rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:.4rem 1.2rem}
  .footer-grid > :first-child{grid-column:1 / -1;margin-bottom:.5rem}
  .site-footer h4{margin:.1rem 0 .45rem}
  .site-footer a{padding:.22rem 0}
}

/* ===================================================================
   PREMIUM UI LAYER (§16) — typography, depth, 3D icons, motion, a11y
   =================================================================== */

/* Display serif headings (Mukta carries Devanagari via the fallback) */
h1,h2,h3{font-family:var(--font-serif);font-weight:600;letter-spacing:-.015em;color:var(--ink)}
.hero h1{font-weight:700}

/* Touch + motion ergonomics */
*{-webkit-tap-highlight-color:transparent}
a,button,.btn,.nav-link,.cat-tile,.seg a,summary,label.btn,input[type=submit]{touch-action:manipulation}
.btn,.fav-btn,.cat-tile,.seg a,.nav-link,.mobile-tabbar a{transition:transform .18s var(--ease-spring),background .15s,box-shadow .25s var(--ease-spring),color .15s}
.btn:active,.cat-tile:active,.fav-btn:active,.seg a:active,.mobile-tabbar a:active{transform:scale(.96)}
:focus-visible{outline:2.5px solid var(--saffron);outline-offset:2px;border-radius:6px}

/* Cards: layered depth + spring lift */
.card{transition:transform .35s var(--ease-spring),box-shadow .35s var(--ease-spring)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}

/* Buttons: subtle gradient + depth */
.btn{background:linear-gradient(180deg,var(--emerald-l),var(--green));box-shadow:0 2px 8px -2px rgba(11,110,80,.45)}
.btn:hover{background:linear-gradient(180deg,var(--green),var(--green-d))}
.btn-gold{background:linear-gradient(180deg,#f6b733,var(--saffron));color:#3a2600}
.btn-gold:hover{background:linear-gradient(180deg,var(--saffron),var(--saffron-d))}
.btn-danger{background:linear-gradient(180deg,#f24168,var(--crimson))}
.btn-ghost{background:#fff;box-shadow:var(--shadow-sm)}
.btn-post{background:linear-gradient(180deg,var(--emerald-l),var(--green))}

/* Hero: emerald with a warm saffron glow */
.hero{background:radial-gradient(900px 360px at 85% -20%,rgba(245,158,11,.30),transparent 60%),linear-gradient(135deg,var(--green),var(--green-d))}

/* HD "3D" squircle category icons (app-icon feel) */
.cat-tile{border-radius:var(--radius-lg);padding:1.1rem .8rem;transition:transform .3s var(--ease-spring),box-shadow .3s var(--ease-spring)}
.cat-tile:hover{transform:translateY(-3px)}
.cat-tile .ic{
  width:62px;height:62px;display:flex;align-items:center;justify-content:center;
  margin:0 auto .55rem;font-size:1.9rem;border-radius:30%;
  background:linear-gradient(145deg,var(--emerald-l),var(--green));
  box-shadow:inset 0 2px 3px rgba(255,255,255,.45),inset 0 -4px 7px rgba(0,0,0,.20),0 10px 20px -8px rgba(11,110,80,.55);
  transition:transform .35s var(--ease-spring)}
.cat-tile:hover .ic{transform:translateY(-2px) rotate(-4deg) scale(1.07)}
.cat-grid .cat-tile:nth-child(6n+2) .ic{background:linear-gradient(145deg,#f7b733,var(--saffron));box-shadow:inset 0 2px 3px rgba(255,255,255,.5),inset 0 -4px 7px rgba(0,0,0,.18),0 10px 20px -8px rgba(245,158,11,.5)}
.cat-grid .cat-tile:nth-child(6n+3) .ic{background:linear-gradient(145deg,#3b82f6,#1d4ed8);box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -4px 7px rgba(0,0,0,.2),0 10px 20px -8px rgba(37,99,235,.5)}
.cat-grid .cat-tile:nth-child(6n+4) .ic{background:linear-gradient(145deg,#f43f5e,#be123c);box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -4px 7px rgba(0,0,0,.2),0 10px 20px -8px rgba(225,43,84,.5)}
.cat-grid .cat-tile:nth-child(6n+5) .ic{background:linear-gradient(145deg,#a855f7,#7c3aed);box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -4px 7px rgba(0,0,0,.2),0 10px 20px -8px rgba(124,58,237,.5)}
.cat-grid .cat-tile:nth-child(6n) .ic{background:linear-gradient(145deg,#06b6d4,#0e7490);box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -4px 7px rgba(0,0,0,.2),0 10px 20px -8px rgba(6,182,212,.5)}

/* Trust cues */
.tag-featured{background:linear-gradient(180deg,#f6b733,var(--gold));color:#3a2600;box-shadow:0 2px 6px -1px rgba(224,160,6,.5)}
.verified{color:var(--green);font-weight:600}
.badge-status.st-active{background:#e3f6ec;color:#08543d}

/* Frosted sticky header */
.site-header{background:rgba(255,255,255,.9);-webkit-backdrop-filter:saturate(1.5) blur(8px);backdrop-filter:saturate(1.5) blur(8px)}

/* Respect reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important}
  .card:hover,.cat-tile:hover,.cat-tile:hover .ic{transform:none}
}

/* Touch reliability fixes */
.fav-btn{width:40px;height:40px;z-index:3;font-size:1.1rem}                 /* bigger tap target, above card link */
.sold-overlay{pointer-events:none}                                          /* don't block the card link on sold items */
.combo-list div{min-height:44px;display:flex;align-items:center}            /* finger-friendly options */
.combo-input{cursor:pointer}
.seg a,.pager a{min-height:40px;display:inline-flex;align-items:center;justify-content:center}
