/* ===========================================================================
   paputu.com styles — ported from the toyumuz marketplace design system
   (Yelp-style: clean surface, bold accent, photo cards) with paputu's warm
   orange accent. Shared by every page.
   =========================================================================== */
:root{
  --red:#d95f2b; --red-d:#b94c1d; --ink:#1c1c1c; --muted:#717171; --line:#e6e6e6;
  --soft:#f6f4f1; --bg:#fff; --surface:#fff; --surface2:#fbfaf8; --text2:#333;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 12px 28px -16px rgba(0,0,0,.22);
  /* aliases kept for pages that reference the old token names (admin, forms) */
  --brand:var(--red); --brand-dark:var(--red-d); --brand-soft:#fbe7db;
  --accent:#2f6f6a; --star:#f0a12e; --text:var(--ink); --surface-2:var(--surface2);
  --radius:14px; --radius-sm:10px; --maxw:1160px;
}
/* ---------- dark theme (html[data-theme="dark"]) ---------- */
html[data-theme="dark"]{
  --red:#f07a41; --red-d:#dd6530; --ink:#ededf1; --muted:#9a9aa2; --line:#2d2d33;
  --soft:#212126; --bg:#141417; --surface:#1b1b1f; --surface2:#232329; --text2:#c6c6cd;
  --shadow:0 1px 3px rgba(0,0,0,.5),0 14px 30px -16px rgba(0,0,0,.75);
  --brand-soft:#3a2417;
}
html[data-theme="dark"] body{background:var(--bg)}
html[data-theme="dark"] .qi:hover .qic{background:rgba(240,122,65,.16)}

*{box-sizing:border-box}
.material-symbols-outlined{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;
  font-size:inherit;line-height:1;letter-spacing:normal;text-transform:none;display:inline-flex;
  white-space:nowrap;direction:ltr;vertical-align:middle;-webkit-font-smoothing:antialiased;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24}
html,body{margin:0;padding:0}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);background:var(--surface);-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:1160px;margin:0 auto;padding:0 clamp(16px,4vw,28px)}
/* every page renders at 80% zoom so more fits on screen (same as toyumuz) */
body.z80{zoom:.8}
body.z80 .wrap{max-width:none;padding-left:clamp(20px,2.6vw,56px);padding-right:clamp(20px,2.6vw,56px)}

/* ---------- top nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:var(--surface);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:14px;height:64px}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;flex:0 0 auto}
.brand .mk{width:34px;height:34px;border-radius:9px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;font-family:'Fraunces',serif}
.brand b{font-size:21px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brand b i{color:var(--red);font-style:normal}
.nav-search{flex:1;display:flex;align-items:center;max-width:520px;border:1px solid var(--line);border-radius:999px;
  box-shadow:0 1px 2px rgba(0,0,0,.06);height:42px;background:var(--surface);position:relative}
.nav-search input{border-radius:999px 0 0 999px}
.nav-search button{border-radius:0 999px 999px 0}
.nav-search.hideTop{opacity:0;transform:translateY(-4px);transition:opacity .2s,transform .2s;pointer-events:none}
.nav.scrolled .nav-search.hideTop{opacity:1;transform:none;pointer-events:auto}
.nav-search input{flex:1;border:none;outline:none;font:inherit;font-size:14px;padding:0 14px;min-width:0;background:none;color:var(--ink)}
.nav-search button{border:none;background:var(--red);color:#fff;width:46px;height:100%;cursor:pointer;font-size:15px}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:6px;flex:0 0 auto}
.lnk{background:none;border:none;font:inherit;font-weight:700;font-size:14px;color:var(--ink);cursor:pointer;
  padding:9px 14px;border-radius:8px;text-decoration:none;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.lnk:hover{background:var(--soft)}
.lnk.red{background:var(--red);color:#fff}
.lnk.red:hover{background:var(--red-d)}
.lnk.ghost{border:1px solid var(--line)}
.lang{font-weight:800;min-width:38px;justify-content:center}
.theme-toggle{padding:9px 10px;color:var(--ink)}
.theme-toggle .material-symbols-outlined{font-size:20px}
.acct-chip{display:inline-flex;align-items:center;gap:8px;background:var(--soft);padding:5px 12px 5px 5px;border-radius:999px}
.acct-av{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--red);color:#fff;font-weight:700;font-size:13px}

/* ---------- hero with search ---------- */
/* NB: no overflow:hidden — the search suggestions dropdown must be able to
   extend below the hero. The bg image/overlays are clipped by inset:0. */
.hero{position:relative;z-index:2;color:#fff;text-align:center;padding:clamp(44px,8vw,92px) 0 clamp(40px,6vw,68px);
  background:linear-gradient(120deg,#5e2a10 0%,#a3491c 52%,#d9803e 100%)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(120deg,rgba(64,26,8,.74),rgba(163,73,28,.5) 55%,rgba(217,128,62,.42))}
.hero-in{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 16px}
.hero h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(30px,5.4vw,52px);line-height:1.06;margin:0 0 10px}
.hero p{font-size:clamp(15px,2.3vw,18px);opacity:.94;margin:0 0 26px}
.search{display:flex;align-items:stretch;background:var(--surface);border-radius:14px;box-shadow:0 18px 44px -18px rgba(0,0,0,.5);
  max-width:680px;margin:0 auto;text-align:left;position:relative}
.search .go{border-radius:0 14px 14px 0}
.search .fld{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;padding:10px 16px}
.search .fld+.fld{border-left:1px solid var(--line)}
.search label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.search input{border:none;outline:none;font:inherit;font-size:15px;color:var(--ink);background:none;padding:2px 0;width:100%}
.search select{border:none;outline:none;font:inherit;font-size:15px;color:var(--ink);background:none;padding:2px 0;width:100%}
.search .go{flex:0 0 auto;border:none;background:var(--red);color:#fff;width:64px;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center}
.search .go:hover{background:var(--red-d)}

/* ---------- search suggestions dropdown ---------- */
.sug{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:12px;
  box-shadow:0 24px 50px -18px rgba(0,0,0,.35);z-index:45;display:none;overflow:hidden;text-align:left}
.sug.show{display:block}
.sug-i{display:flex;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;color:var(--ink);font-size:14px;cursor:pointer}
.sug-i:hover,.sug-i.sel{background:var(--soft)}
.sug-i .material-symbols-outlined{font-size:19px;color:var(--red);flex:0 0 auto}
.sug-l{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.sug-l b{color:var(--red)}
.sug-t{color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;flex:0 0 auto}

/* ---------- quick category shortcuts (monochrome icon row) ---------- */
.quick{border-bottom:1px solid var(--line)}
.quick-row{display:flex;flex-wrap:wrap;gap:12px 6px;padding:16px 0 6px;overflow:hidden;max-height:124px;transition:max-height .28s ease}
.quick-row.expanded{max-height:640px}
.qmore{display:flex;align-items:center;gap:5px;width:fit-content;margin:10px auto 14px;border:1px solid var(--line);background:none;border-radius:999px;padding:7px 16px;font:inherit;font-weight:700;font-size:13.5px;color:var(--ink);cursor:pointer}
.qmore .material-symbols-outlined{font-size:18px}
.qmore:hover{background:var(--soft)}
.qmore[hidden]{display:none}
.qi{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:8px;width:92px;padding:8px 4px;border-radius:12px;text-decoration:none;color:var(--ink);cursor:pointer}
.qi:hover{background:var(--soft)}
.qi .qic{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;background:var(--soft);color:var(--red)}
.qi:hover .qic{background:var(--brand-soft)}
.qi .qn{font-size:12.5px;font-weight:600;text-align:center;line-height:1.15}

/* ---------- sections + category photo cards ---------- */
.sec{padding:34px 0 8px}
.sec h2{font-size:clamp(20px,3vw,26px);font-weight:800;margin:0 0 4px}
.sec .sub{color:var(--muted);font-size:14px;margin:0 0 18px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px}
.sec-head h2{margin:0 0 2px}
.sec-head .sub{margin:0}
.seeall{flex:0 0 auto;color:var(--red);font-weight:700;font-size:14px;text-decoration:none;white-space:nowrap}
.seeall:hover{text-decoration:underline}
/* ---------- featured carousel ---------- */
.vrow{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(210px,1fr);gap:18px;overflow-x:auto;
  padding:2px 2px 8px;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.vrow::-webkit-scrollbar{display:none}
.vrow .vcard{scroll-snap-align:start}

/* ---------- provider cards ---------- */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:22px;padding:8px 0 10px}
.vcard{display:flex;flex-direction:column;text-decoration:none;color:inherit;cursor:pointer}
.vcard .vthumb{aspect-ratio:3/2;border-radius:14px;overflow:hidden;position:relative;background:linear-gradient(135deg,#eee,#ddd);
  box-shadow:var(--shadow);transition:transform .16s,box-shadow .16s;display:flex;align-items:center;justify-content:center;font-size:40px;color:rgba(255,255,255,.9)}
.vcard .vthumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vcard:hover .vthumb{transform:translateY(-3px);box-shadow:0 18px 36px -18px rgba(0,0,0,.4)}
.vcard .vname{font-weight:700;font-size:16px;margin:11px 0 2px;display:flex;align-items:center;gap:6px;line-height:1.2}
.vcard .vname .vok{color:var(--accent);font-size:17px}
.vcard .vr{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-top:2px}
.vcard .vmeta{color:var(--muted);font-size:13.5px;margin-top:3px}
.rate{font-weight:700;color:var(--ink)}
.rstars{display:inline-flex;font-size:17px;line-height:1}
.rstars .material-symbols-outlined{font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24}
.rstars .s-full,.rstars .s-half{color:var(--red)}
.rstars .s-empty{color:#e7dcde}
html[data-theme="dark"] .rstars .s-empty{color:#3a3a41}
.feat{position:absolute;top:10px;left:10px;font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--red);border-radius:6px;padding:3px 8px}

/* ---------- listing page: heading, chips, toolbar ---------- */
.lhead{padding:26px 0 4px;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.lhead h1{font-size:clamp(22px,3.4vw,30px);font-weight:800;margin:0 0 2px}
.lhead .cnt{color:var(--muted);font-size:14px}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:14px 0 4px}
.toolbar .search{flex:1;min-width:240px;max-width:640px;margin:0;box-shadow:0 1px 3px rgba(0,0,0,.08);border:1px solid var(--line)}
.toolbar .search label{display:none}
.toolbar .search .fld{padding:12px 16px}
.toolbar .search .fld+.fld{flex:0.55}
.toolbar .search .go{width:54px;font-size:18px}
.chips{display:flex;gap:8px;overflow-x:auto;padding:14px 0 10px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:8px 14px;font:inherit;
  font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;white-space:nowrap;display:inline-flex;gap:6px;align-items:center;text-decoration:none}
.chip:hover{border-color:#bdbdbd}
.chip.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.empty{padding:50px 0;text-align:center;color:var(--muted)}
.chip .material-symbols-outlined{font-size:17px}
/* list / grid view toggle */
.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.view-toggle button{border:0;background:var(--surface);padding:8px 13px;cursor:pointer;color:var(--muted);display:flex;font-size:18px}
.view-toggle button.on{background:var(--soft);color:var(--red)}
.lh-tools{display:flex;align-items:center;gap:10px}

/* ---------- results: left filter rail + list (toyumuz vendors layout) ------ */
.results{display:grid;grid-template-columns:230px 1fr;gap:26px;align-items:start;padding:6px 0 0}
.filters{position:sticky;top:80px;align-self:start}
.fgroup{border-bottom:1px solid var(--line);padding:14px 0}
.fgroup:first-child{padding-top:4px}
.fgroup h4{margin:0 0 10px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.fopt{display:flex;align-items:center;gap:9px;padding:6px 0;font-size:14px;cursor:pointer}
.fopt input{accent-color:var(--red);width:16px;height:16px}
.pricepick{display:flex;gap:6px;flex-wrap:wrap}
.pricepick button{border:1px solid var(--line);background:var(--surface);border-radius:9px;padding:7px 12px;font:inherit;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink)}
.pricepick button.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.fgroup select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font:inherit;font-size:14px;background:var(--surface2);color:var(--ink);outline:none}

/* ---------- mobile filter drawer chrome (hidden on desktop) ---------- */
.filter-btn{display:none;align-items:center;gap:7px;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 13px;font:inherit;font-weight:700;font-size:14px;color:var(--ink);cursor:pointer}
.filter-btn .material-symbols-outlined{font-size:19px}
.filter-btn:hover{background:var(--soft)}
.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-weight:800}
.filter-count[hidden]{display:none}
.filters-head{display:none;align-items:center;gap:12px;position:sticky;top:0;background:var(--surface);padding:16px 0 12px;border-bottom:1px solid var(--line);z-index:1}
.filters-head b{font-size:17px;font-weight:800}
.filters-clear{margin-left:auto;border:0;background:none;font:inherit;font-weight:700;font-size:14px;color:var(--red);cursor:pointer;padding:4px}
.filters-close{border:0;background:var(--soft);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);flex:0 0 auto}
.filters-close .material-symbols-outlined{font-size:20px}
.filters-apply{display:none;width:100%;margin-top:16px;border:0;background:var(--red);color:#fff;font:inherit;font-weight:800;font-size:15px;padding:14px;border-radius:12px;cursor:pointer}
.filters-apply:hover{background:var(--red-d)}
.filters-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:55}

/* list-style result rows */
.rcard{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit}
.rthumb{flex:0 0 230px;aspect-ratio:3/2;border-radius:14px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;
  font-size:36px;color:rgba(255,255,255,.9);box-shadow:var(--shadow);transition:transform .16s}
.rthumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rcard:hover .rthumb{transform:translateY(-2px)}
.rinfo{flex:1;min-width:0}
.rname{display:flex;align-items:center;gap:8px;font-weight:800;font-size:18px;line-height:1.25;flex-wrap:wrap}
.rname .feat{position:static}
.rname .vok{color:var(--accent);font-size:19px}
.rrate{display:flex;align-items:center;gap:7px;font-size:14px;color:var(--muted);margin-top:5px}
.rmeta{color:var(--muted);font-size:14px;margin-top:4px}
.rdesc{color:var(--text2);font-size:14.5px;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- provider detail: two-column header (toyumuz vendor.html) ------- */
.vp-top{display:grid;grid-template-columns:minmax(280px,480px) 1fr;gap:30px;align-items:start;margin-top:14px}
.vp-photo{aspect-ratio:4/3;border-radius:16px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;
  font-size:56px;color:rgba(255,255,255,.9);box-shadow:var(--shadow)}
.vp-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vp-info h1{font-size:clamp(26px,4vw,38px);font-weight:800;margin:0 0 8px;display:flex;align-items:center;gap:10px;line-height:1.1}
.vp-info h1 .vok{color:var(--accent);font-size:26px}
.vp-meta{color:var(--muted);font-size:15px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}
.vp-btns{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px}
.vp-btns .lnk{border:1px solid var(--line);padding:10px 16px;border-radius:11px;font-size:14.5px}
.vp-btns .lnk.wa{background:#25d366;color:#fff;border-color:transparent}
.vp-btns .lnk.wa:hover{background:#1fb857}
.vp-btns .lnk .material-symbols-outlined{font-size:19px}
.svc-chips{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 0}
.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.gal a{display:block;aspect-ratio:4/3;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.gal img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- collapsible sections (prices / previous works) ---------------- */
.acc{border:1px solid var(--line);border-radius:16px;margin-top:22px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden}
.acc-head{width:100%;display:flex;align-items:center;gap:10px;padding:16px 20px;background:none;border:0;font:inherit;
  font-weight:800;font-size:17px;color:var(--ink);cursor:pointer;text-align:left}
.acc-head .cnt2{color:var(--muted);font-weight:600;font-size:14px}
.acc-head .chev{margin-left:auto;color:var(--muted);transition:transform .18s;font-size:22px}
.acc.open .acc-head .chev{transform:rotate(180deg)}
.acc-body{display:none;padding:0 20px 20px}
.acc.open .acc-body{display:block}
/* per-unit price catalogue rows */
.plist{margin:0}
.pli{display:flex;align-items:baseline;gap:12px;padding:11px 0;border-bottom:1px dashed var(--line);font-size:15px}
.pli:last-child{border-bottom:none}
.pli .pn{flex:1;min-width:0}
.pli .dots{flex:1;border-bottom:1px dotted var(--line);opacity:.6}
.pli .pp{font-weight:800;white-space:nowrap}
.pli .pu{color:var(--muted);font-weight:600;font-size:13px;white-space:nowrap}

/* ---------- cabinet: price-list editor + gallery manager ------------------ */
.plr{display:grid;grid-template-columns:1fr 96px 96px 36px;gap:8px;margin-bottom:8px;align-items:center}
.plr input,.plr select{border:1px solid var(--line);background:var(--surface2);color:var(--ink);border-radius:9px;padding:9px 10px;font:inherit;font-size:14px;outline:none;min-width:0}
.plr input:focus,.plr select:focus{border-color:var(--red)}
.plr .rm{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:9px;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.plr .rm:hover{color:#c53434;border-color:#c53434}
.tpl-chips{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 14px}
.tpl-chips .chip{font-size:12.5px;padding:6px 11px}
.gm{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:12px}
.gmi{position:relative;aspect-ratio:4/3;border-radius:10px;overflow:hidden;background:var(--soft);box-shadow:var(--shadow)}
.gmi img{width:100%;height:100%;object-fit:cover;display:block}
.gmi .rm{position:absolute;top:5px;right:5px;width:26px;height:26px;border:0;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px}
.gmi .rm:hover{background:#c53434}
.cab-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;border-radius:999px;padding:5px 12px}
.cab-status.live{background:rgba(46,158,91,.14);color:#2e9e5b}
.cab-status.pending{background:var(--brand-soft);color:var(--red-d)}
@media (max-width:620px){ .plr{grid-template-columns:1fr 76px 82px 32px} }

/* ---------- single provider profile ---------- */
.vp{padding:8px 0 0}
.vp-hero{aspect-ratio:21/8;min-height:200px;border-radius:18px;overflow:hidden;position:relative;background:linear-gradient(135deg,#eee,#ddd);display:flex;align-items:center;justify-content:center;font-size:64px;color:rgba(255,255,255,.9);box-shadow:var(--shadow)}
.vp-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vp-head{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start;margin:20px 0 6px}
.vp-head h1{font-size:clamp(24px,4vw,34px);font-weight:800;margin:0;display:flex;align-items:center;gap:8px}
.vp-head h1 .vok{color:var(--accent);font-size:24px}
.vp-head .vp-sub{color:var(--muted);font-size:15px;margin-top:6px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.vp-actions{margin-left:auto;display:flex;flex-wrap:wrap;gap:8px}
.vp-desc{font-size:16px;line-height:1.6;color:var(--text2);max-width:760px;margin:14px 0;white-space:pre-line}
.backlink{display:inline-flex;align-items:center;gap:6px;color:var(--muted);text-decoration:none;font-weight:600;font-size:14px;margin:18px 0 0}
.backlink:hover{color:var(--ink)}
.dot{color:var(--line)}

/* ---------- reviews ---------- */
.review{padding:16px 0;border-top:1px solid var(--line)}
.review-head{display:flex;align-items:center;gap:10px}
.review-av{width:34px;height:34px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;font-weight:700}
.stars-input{display:inline-flex;gap:2px;cursor:pointer}
.stars-input .material-symbols-outlined{color:var(--line);font-size:28px}
.stars-input .material-symbols-outlined.on{color:var(--star);font-variation-settings:'FILL' 1}

/* ---------- generic page heading (forms pages) ---------- */
.page-head{padding:26px 0 4px}
.page-head h1{font-size:clamp(22px,3.4vw,30px);font-weight:800;margin:0 0 2px}
.page-head p{color:var(--muted);font-size:14.5px;margin:4px 0 0;max-width:56ch}

/* ---------- buttons & forms (auth / join / post-job / admin) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;font:inherit;font-weight:700;
  padding:10px 18px;border-radius:10px;background:var(--soft);color:var(--ink);text-decoration:none;transition:background .15s,transform .06s}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:var(--red);color:#fff}
.btn.primary:hover{background:var(--red-d)}
.btn.ghost{background:transparent;border:1px solid var(--line)}
.btn.block{width:100%}
.btn.lg{padding:12px 22px;font-size:15px}
.btn[disabled]{opacity:.6;cursor:default}
.card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:24px}
.center-narrow{max-width:460px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1 / -1}
.field-lg{display:flex;flex-direction:column;gap:5px}
.field-lg label{font-size:12.5px;font-weight:700;color:var(--muted)}
.field-lg input,.field-lg select,.field-lg textarea{border:1px solid var(--line);background:var(--surface2);color:var(--ink);
  border-radius:10px;padding:10px 12px;font:inherit;font-size:14px;outline:none;transition:border-color .15s}
.field-lg input:focus,.field-lg select:focus,.field-lg textarea:focus{border-color:var(--red)}
.field-lg textarea{resize:vertical;min-height:90px}
.form-note{padding:11px 14px;border-radius:10px;margin-top:12px;font-size:14px}
.form-note.ok{background:rgba(46,158,91,.14);color:#2e9e5b}
.form-note.err{background:rgba(214,69,69,.14);color:#c53434}
.tabs{display:inline-flex;background:var(--soft);padding:4px;border-radius:12px;margin-bottom:18px}
.tabs button{border:0;background:transparent;color:var(--muted);font:inherit;font-weight:700;padding:8px 16px;border-radius:9px;cursor:pointer}
.tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.seg{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.seg-btn{display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;border:1.5px solid var(--line);background:var(--surface2);
  color:var(--ink);border-radius:12px;padding:13px 10px;cursor:pointer;font:inherit;transition:border-color .15s,background .15s}
.seg-btn .material-symbols-outlined{font-size:25px;color:var(--muted)}
.seg-btn b{font-weight:700;font-size:14.5px}
.seg-btn small{color:var(--muted);font-size:12px}
.seg-btn.on{border-color:var(--red);background:var(--brand-soft)}
.seg-btn.on .material-symbols-outlined{color:var(--red-d)}
.icon-btn{border:1px solid var(--line);background:var(--surface);color:var(--ink);width:38px;height:38px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.icon-btn:hover{background:var(--soft)}
.icon-btn .material-symbols-outlined{font-size:20px}
.skeleton{background:linear-gradient(90deg,var(--soft),var(--surface),var(--soft));background-size:200% 100%;animation:sk 1.2s infinite;border-radius:14px}
@keyframes sk{to{background-position:-200% 0}}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--line);margin-top:44px;padding:24px 0 44px;color:var(--muted);font-size:13px;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.foot a{color:var(--muted);text-decoration:none}
.foot a:hover{color:var(--ink)}

/* ---------- responsive ---------- */
@media (max-width:620px){
  .hero{padding:30px 0 26px}
  .hero h1{font-size:25px;margin-bottom:6px}
  .hero p{font-size:14px;margin-bottom:18px}
  .hero .search{flex-wrap:wrap}
  .hero .search .go{width:100%;height:48px;border-radius:0 0 12px 12px}
  .hero .search .fld+.fld{border-left:none;border-top:1px solid var(--line)}
  .nav-search.hideTop{display:none}
  .lnk.hideSm{display:none}
  .quick-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px 4px;overflow:visible;max-height:none}
  .qi{width:auto}
  .qi .qic{width:54px;height:54px}
  .qi .qn{font-size:11.5px}
  .sec{padding:24px 0 6px}
  .sec-head{align-items:center}
  .vgrid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
  .vrow{grid-auto-columns:minmax(168px,1fr);gap:14px}
  .vp-actions{margin-left:0;width:100%}
  .toolbar .search{flex:1 0 100%;max-width:none}
  .form-grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .results{grid-template-columns:1fr}
  /* filters collapse into a slide-up drawer, opened by the "Filtrlər" button */
  .filter-btn{display:inline-flex}
  .filters{position:fixed;left:0;right:0;bottom:0;top:auto;z-index:60;display:block;align-self:auto;
    max-height:88vh;overflow-y:auto;background:var(--surface);border-radius:18px 18px 0 0;
    box-shadow:0 -18px 44px -12px rgba(0,0,0,.45);margin:0;
    padding:0 18px calc(18px + env(safe-area-inset-bottom));
    transform:translateY(101%);visibility:hidden;
    transition:transform .3s ease,visibility 0s linear .3s}
  .filters.open{transform:none;visibility:visible;transition:transform .3s ease,visibility 0s}
  .filters-head{display:flex}
  .filters-apply{display:block}
  .fgroup:first-child{padding-top:14px}
  body.filters-open{overflow:hidden}
  .rthumb{flex-basis:140px;font-size:26px}
  .rname{font-size:16px}
  .rdesc{display:none}
  .vp-top{grid-template-columns:1fr;gap:18px}
}
