/* ====================================================================
   Finnting — design system
   Brand: green (gjenbruk / bærekraft). Clean, finn.no-grade marketplace.
   ==================================================================== */

:root{
  --brand:#1F6B4A; --brand-dk:#13452F; --brand-ll:#e6f2eb;
  --ink:#1C2421; --muted:#5A635E; --line:#e6e8eb; --bg:#F6F4EF;
  --card:#fff; --radius:14px; --radius-sm:9px;
  --shadow:0 1px 3px rgba(20,30,40,.07),0 6px 18px rgba(20,30,40,.05);
  --shadow-hover:0 4px 12px rgba(20,30,40,.10),0 14px 34px rgba(20,30,40,.10);
  --maxw:1200px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;border-radius:999px;
  padding:11px 20px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-dk)}
.btn-light{background:#fff;color:var(--brand)}
.btn-light:hover{background:#f0f0f0}
.btn-outline{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--brand);color:var(--brand)}
.btn-block{display:flex;width:100%}
.btn-lg{padding:14px 30px;font-size:16px}

/* ---- Top bar ---- */
.topbar{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 1px 2px rgba(0,0,0,.03)}
.topbar-inner{display:flex;align-items:center;gap:18px;height:64px}
.logo{display:inline-flex;align-items:center;gap:7px;font-size:23px;font-weight:800;letter-spacing:-.02em;color:#13452F;line-height:1}
.logo-mark{flex:0 0 auto;display:block}
.logo-word{color:#13452F}
.logo-sm{font-size:19px}
.logo-sm .logo-mark{width:22px;height:22px}
.topsearch{flex:1;display:flex;max-width:560px;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;background:#fff;transition:.15s}
.topsearch:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.topsearch input{flex:1;border:0;padding:10px 18px;font-size:15px;outline:0;background:transparent}
.topsearch button{border:0;background:transparent;padding:0 16px;font-size:17px;cursor:pointer}
.topnav{display:flex;align-items:center;gap:14px;margin-left:auto}
.topnav-link{font-weight:600;font-size:14px;color:var(--muted)}
.topnav-link:hover{color:var(--brand)}

/* ---- Category nav strip ---- */
.catnav{background:#fff;border-bottom:1px solid var(--line)}
.catnav-inner{display:flex;flex-wrap:wrap;gap:6px;padding:8px 20px}
.catnav-link{flex:0 0 auto;padding:7px 14px;border-radius:999px;font-size:14px;font-weight:600;color:var(--muted);white-space:nowrap}
.catnav-link:hover{background:var(--bg);color:var(--ink)}
.catnav-link.active{background:var(--brand-ll);color:var(--brand-dk)}

.main{padding:28px 20px 60px;min-height:60vh}

/* ---- Hero ---- */
.hero{background:linear-gradient(135deg,#13452F 0%,#1F6B4A 52%,#2E9C68 100%);color:#fff;
  border-radius:22px;padding:54px 40px;margin-bottom:36px;text-align:center;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.07)}
.hero::before{content:"";position:absolute;left:-40px;bottom:-90px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.06)}
.hero h1{font-size:clamp(28px,4vw,44px);line-height:1.1;position:relative}
.hero h1 span{color:#F2C879}
.hero-sub{font-size:17px;opacity:.92;margin:12px 0 26px;position:relative}
.hero-tabs{display:inline-flex;gap:6px;background:rgba(255,255,255,.16);padding:5px;border-radius:999px;margin-bottom:16px;position:relative}
.hero-tab{border:0;background:transparent;color:#ddefe4;font-weight:600;font-size:15px;padding:9px 22px;border-radius:999px;cursor:pointer}
.hero-tab.active{background:#fff;color:var(--brand-dk)}
.hero-search{display:flex;gap:8px;max-width:660px;margin:0 auto;position:relative;background:#fff;padding:8px;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.hero-search input,.hero-search select{border:0;padding:12px 14px;font-size:15px;border-radius:10px;outline:0;font-family:inherit;background:#f3f4f6;color:var(--ink)}
.hero-search input{flex:1}
.hero-search select{max-width:170px}

/* ---- Section titles ---- */
.section-title{font-size:21px;margin:34px 0 16px}

/* ---- Category grid ---- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.cat-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 16px;
  display:flex;flex-direction:column;gap:5px;transition:.15s;border-top:3px solid var(--accent,var(--brand))}
.cat-tile:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.cat-ico{font-size:30px}
.cat-name{font-weight:700;font-size:15px}
.cat-count{color:var(--muted);font-size:13px}

/* ---- Listing grid + cards ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.15s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.card-img{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative}
.card-body{padding:13px 14px 15px}
.card-price{font-weight:800;font-size:17px;margin-bottom:3px}
.price-neg{font-weight:500;color:var(--muted);font-size:13px}
.card-title{font-size:14.5px;font-weight:600;line-height:1.3;margin-bottom:4px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-sub{font-size:13px;color:var(--muted);margin-bottom:8px}
.card-meta{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);gap:6px}
.card-meta span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;letter-spacing:.02em}
.badge-feat{background:#E8A33D;color:#4a3300}
.fav-btn{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:50%;border:0;background:rgba(255,255,255,.92);
  color:#9aa3ab;font-size:17px;cursor:pointer;display:grid;place-items:center;transition:.15s}
.fav-btn:hover{background:#fff;color:#C8553D}
.fav-btn.on{color:#C8553D}

.empty{color:var(--muted);padding:40px 0;text-align:center;font-size:15px}

/* ---- Vertical / page headers ---- */
.vhead{border-left:4px solid var(--accent,var(--brand));padding:4px 0 4px 16px;margin-bottom:22px}
.vhead h1{font-size:26px}
.vhead p{color:var(--muted);margin:5px 0 0}

/* ---- Results layout (sidebar + grid) ---- */
.results-layout{display:grid;grid-template-columns:262px 1fr;gap:26px;align-items:start}
.sidebar{position:sticky;top:84px}
.filters{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:14px}
.filter-group{display:flex;flex-direction:column;gap:5px}
.filter-group label{font-size:13px;font-weight:600;color:var(--muted)}
.filters input,.filters select{border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:9px 11px;font-size:14px;font-family:inherit;outline:0;background:#fff;width:100%}
.filters input:focus,.filters select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.range{display:flex;gap:8px}
.filter-reset{text-align:center;font-size:13px;color:var(--muted)}
.filter-reset:hover{color:var(--brand)}
.results-bar{margin-bottom:14px;color:var(--muted);font-size:14px}
.results-bar strong{color:var(--ink);font-size:16px}

/* ---- Listing detail ---- */
.crumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.crumbs a:hover{color:var(--brand)}
.crumbs span{color:var(--ink)}
.listing{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
.listing-main{display:flex;flex-direction:column;gap:18px}
.gallery-main{aspect-ratio:3/2;border-radius:var(--radius);background-size:cover;background-position:center;position:relative;box-shadow:var(--shadow)}
.card-block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.card-block h2{font-size:17px;margin-bottom:12px}
.desc{white-space:pre-line;color:#33393e}
.spec{width:100%;border-collapse:collapse}
.spec th,.spec td{text-align:left;padding:10px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.spec th{color:var(--muted);font-weight:500;width:42%}
.spec td{font-weight:600}
.spec tr:last-child th,.spec tr:last-child td{border-bottom:0}

.listing-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
.price-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.big-price{font-size:28px;font-weight:800;margin-bottom:6px}
.listing-title{font-size:20px;line-height:1.25;margin-bottom:8px}
.listing-loc{color:var(--muted);font-size:14px;margin-bottom:16px}
.price-box .btn{margin-bottom:10px}
.contact-info{margin-top:8px;border-top:1px solid var(--line);padding-top:14px}
.seller{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.seller-avatar{width:42px;height:42px;border-radius:50%;background:var(--brand-ll);color:var(--brand-dk);
  display:grid;place-items:center;font-weight:700;font-size:18px}
.seller-name{font-weight:700}
.seller-since{font-size:12.5px;color:var(--muted)}
.contact-row{display:block;padding:9px 0;font-weight:600;color:var(--brand-dk)}
.annonse-id{margin-top:14px;font-size:12px;color:var(--muted)}
.safety{background:var(--brand-ll);border-radius:var(--radius);padding:18px 20px}
.safety h3{font-size:15px;margin-bottom:8px}
.safety ul{margin:0;padding-left:18px;color:#214a37;font-size:13.5px}
.safety li{margin-bottom:4px}

/* ---- CTA band ---- */
.cta-band{margin-top:44px;background:var(--ink);color:#fff;border-radius:var(--radius);padding:28px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.cta-band h3{font-size:20px}
.cta-band p{color:#c3c9ce;margin:4px 0 0}

/* ---- Forms (post ad) ---- */
.adform{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;max-width:880px}
.adform-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.adform label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--muted)}
.adform label.full{grid-column:1/-1}
.adform input,.adform select,.adform textarea{border:1.5px solid var(--line);border-radius:var(--radius-sm);
  padding:11px 12px;font-size:15px;font-family:inherit;color:var(--ink);outline:0;background:#fff}
.adform input:focus,.adform select:focus,.adform textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.adform fieldset{grid-column:1/-1;border:1px dashed var(--line);border-radius:var(--radius);padding:18px;margin:0}
.adform legend{font-weight:700;color:var(--ink);padding:0 8px;font-size:14px}
.adform>.btn{margin-top:20px}

/* Reg-number lookup box ("Finn bilen din") */
.reglookup{grid-column:1/-1;background:var(--brand-ll);border:1px solid #cfe7d8;border-radius:var(--radius);padding:16px 18px;margin-bottom:4px}
.reglookup>label{font-weight:700;color:var(--ink);display:block;margin-bottom:3px;font-size:15px}
.reg-help{margin:0 0 10px;font-size:13.5px;color:var(--muted)}
.reg-row{display:flex;gap:8px;flex-wrap:wrap}
.reg-input{flex:1 1 200px;text-transform:uppercase;letter-spacing:2px;font-weight:700;border:1.5px solid #a9d3bd;border-radius:var(--radius-sm);padding:11px 14px;font-size:16px;font-family:inherit;outline:0;background:#fff}
.reg-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(31,107,74,.15)}
.reg-status{margin:10px 0 0;font-size:13.5px;font-weight:600}
.reg-status.reg-ok{color:var(--brand-dk)}
.reg-status.reg-err{color:#c0392b}
.reg-status.reg-busy{color:var(--muted)}

/* ---- Flash / misc ---- */
.flash{border-radius:var(--radius);padding:16px 20px;margin-bottom:20px;font-size:15px}
.flash-ok{background:var(--brand-ll);color:var(--brand-dk)}
.flash-ok a{font-weight:700;text-decoration:underline}
.flash-err{background:#fdecec;color:#a12525}
.flash-err ul{margin:6px 0 0;padding-left:20px}
.prose{max-width:640px;color:#33393e}
.notfound{text-align:center;padding:60px 0}
.notfound h1{font-size:72px;color:var(--brand)}
.notfound p{color:var(--muted);margin:8px 0 20px}

/* ---- Footer ---- */
.footer{background:#fff;border-top:1px solid var(--line);margin-top:50px;padding:40px 0 0}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px;padding-bottom:30px}
.footer-col h4{font-size:14px;margin-bottom:12px}
.footer-col p{color:var(--muted);font-size:14px;max-width:240px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:8px}
.footer-col a{color:var(--muted);font-size:14px}
.footer-col a:hover{color:var(--brand)}
.footer-base{border-top:1px solid var(--line);padding:18px 20px;color:var(--muted);font-size:13px;text-align:center}

/* ---- Property: filters facilities ---- */
.facilities-filter{display:flex;flex-direction:column;gap:6px;max-height:210px;overflow-y:auto}
.fac-check{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:500;color:var(--ink);cursor:pointer}
.fac-check input{width:auto;flex:0 0 auto}
.fac-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:7px}

/* ---- Property: detail price block ---- */
.badge-deal{left:auto;right:10px;background:var(--brand);color:#fff}
.price-block{margin-bottom:14px}
.price-block .big-price{font-size:26px;font-weight:800;margin-bottom:10px}
.price-block .pb-per{font-size:16px;font-weight:600;color:var(--muted)}
.pb-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;font-size:14.5px;color:#33393e}
.pb-row span:last-child{font-weight:600;text-align:right}
.pb-total{border-top:1.5px solid var(--line);margin-top:4px;padding-top:10px;font-size:16px;font-weight:800;color:var(--ink)}
.pb-total span:last-child{font-weight:800}
.pb-sep{border-top:1px dashed var(--line);margin:8px 0}

/* ---- Property: facilities list ---- */
.fac-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
.fac-list li{font-size:14.5px;color:#33393e}

/* ---- Property: megler box ---- */
.megler-box{margin-top:8px;border-top:1px solid var(--line);padding-top:14px}
.megler-head{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.megler-logo{width:42px;height:42px;border-radius:10px;background:#c0772b;color:#fff;display:grid;place-items:center;font-weight:800;font-size:19px}
.megler-office{font-weight:700}
.megler-role{font-size:12.5px;color:var(--muted)}
.megler-agent{font-size:13.5px;color:#33393e;margin-bottom:8px}
.bud-note{font-size:12.5px;color:var(--muted);margin:10px 0 0}

/* ---- Property: docs + loan ---- */
.doc-list{list-style:none;margin:0;padding:0}
.doc-list li{padding:7px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.doc-list li:last-child{border-bottom:0}
.doc-list a{color:var(--brand-dk);font-weight:600}
.doc-list a:hover{text-decoration:underline}
.doc-note{font-size:12.5px;color:var(--muted);margin:12px 0 0}
.loan-calc h3{font-size:15px;margin-bottom:8px}
.loan-calc p{font-size:13px;color:var(--muted);margin:0 0 6px}
.loan-est{font-size:22px;font-weight:800;color:var(--brand-dk);margin:6px 0}
.loan-note{font-size:12px;color:var(--muted);margin-top:6px}

/* ---- Post-ad: property price fieldset ---- */
.price-fieldset{border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:#fafbfc}
.price-fieldset-head{font-weight:700;font-size:14px;margin-bottom:12px;color:var(--ink)}

/* ---- Selg bolig landing ---- */
.sell-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start;margin-bottom:22px}
.sell-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.sell-opt h3{font-size:15px;margin-bottom:8px;color:var(--brand-dk)}
.sell-opt ul{margin:0 0 12px;padding-left:18px;font-size:13.5px;color:#33393e}
.sell-opt li{margin-bottom:5px}
.sell-form .adform-grid{margin-top:12px}
.sell-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--muted)}
.sell-form label.full{grid-column:1/-1}
.sell-form input,.sell-form select{border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:11px 12px;font-size:15px;font-family:inherit;color:var(--ink);outline:0;background:#fff;width:100%}
.sell-form input:focus,.sell-form select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.sell-form>.btn{margin-top:16px}
.legal-note ul{margin:10px 0}
.adr-input{text-transform:none;letter-spacing:normal}

/* ---- Responsive ---- */
@media(max-width:900px){
  .results-layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .listing{grid-template-columns:1fr}
  .listing-side{position:static}
  .footer-inner{grid-template-columns:1fr 1fr}
  .sell-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .sell-cols{grid-template-columns:1fr}
  .fac-list{grid-template-columns:1fr}
}
@media(max-width:640px){
  .topsearch{display:none}
  .hero{padding:36px 22px}
  .hero-search{flex-direction:column}
  .hero-search select{max-width:none}
  .adform-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
}

/* ---- Hero searchlight: a soft "looking for things" spot drifting across the hero ---- */
.hero{position:relative;overflow:hidden;isolation:isolate}
.hero-spot{position:absolute;top:-25%;left:-15%;width:48%;height:150%;z-index:0;pointer-events:none;border-radius:50%;
  background:radial-gradient(circle at center,rgba(255,255,255,.45) 0%,rgba(255,255,255,.18) 38%,rgba(255,255,255,0) 66%);
  filter:blur(6px);mix-blend-mode:screen;will-change:transform;
  animation:hero-search 17s cubic-bezier(.45,.05,.55,.95) infinite}
.hero > h1,.hero > .hero-sub,.hero > .hero-tabs,.hero > .hero-search{position:relative;z-index:2}
@keyframes hero-search{
  0%{transform:translate(-8%,6%) scale(1)}
  22%{transform:translate(120%,-4%) scale(1.12)}
  44%{transform:translate(165%,28%) scale(1)}
  68%{transform:translate(55%,42%) scale(1.15)}
  88%{transform:translate(0%,18%) scale(1.02)}
  100%{transform:translate(-8%,6%) scale(1)}
}
@media (prefers-reduced-motion: reduce){.hero-spot{animation:none;opacity:.5}}

/* --- Auth (login / register / min side) --- */
.auth-wrap{display:flex;justify-content:center;padding:24px 0 48px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;width:100%;max-width:440px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.auth-card h1{font-size:24px;margin-bottom:6px}
.auth-sub{color:var(--muted);font-size:14px;margin-bottom:20px}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:14px}
.auth-form input{padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-weight:400}
.auth-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll);outline:none}
.auth-form .btn{margin-top:4px}
.auth-alt{margin-top:18px;text-align:center;font-size:14px;color:var(--muted)}
.auth-alt a{color:var(--brand-dk);font-weight:600}
.auth-or{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px;margin:16px 0}
.auth-or:before,.auth-or:after{content:"";flex:1;height:1px;background:var(--line)}
.auth-pk-status{margin:12px 0 0;font-size:14px;color:var(--muted)}
.auth-pk-status.reg-ok{color:var(--brand-dk)}
.auth-pk-status.reg-err{color:#a12525}
.auth-pk-status.reg-busy{color:var(--muted)}
.account-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.passkey-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.passkey-list li{padding:10px 12px;background:var(--brand-ll);border-radius:10px;font-size:14px}
.passkey-meta{color:var(--muted);font-weight:400;margin-left:6px}

/* ---- Free-2026 hero badge ---- */
.hero-badge{display:inline-block;background:#E8A33D;color:#3a2a00;font-weight:700;font-size:14px;padding:7px 16px;border-radius:999px;margin:0 0 18px;position:relative;z-index:2}
.hero-badge strong{font-weight:800}
/* ---- Info / legal doc pages ---- */
.prose-doc{max-width:760px;color:#33393e}
.prose-doc h1,.prose-doc h2,.prose-doc h3{margin:22px 0 8px;color:var(--brand-dk)}
.prose-doc h2{font-size:20px}.prose-doc h3{font-size:16px}
.prose-doc p,.prose-doc li{font-size:15px;line-height:1.65}
.prose-doc ul,.prose-doc ol{padding-left:22px;margin:10px 0}
.prose-doc a{color:var(--brand);text-decoration:underline}
.prose-doc hr{border:0;border-top:1px solid var(--line);margin:22px 0}
.prose-doc table{border-collapse:collapse;width:100%;margin:14px 0}
.prose-doc th,.prose-doc td{border:1px solid var(--line);padding:7px 10px;text-align:left;font-size:14px}
.prose-doc th{background:#efeae0}

/* Fix: hero search panes are toggled via the [hidden] attribute (the .hero-search
   display:flex rule was overriding the browser default [hidden]{display:none}). */
.hero-search[hidden]{display:none}

/* a11y: visible keyboard focus */
a:focus-visible,button:focus-visible,.card:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--brand-dk);outline-offset:2px;border-radius:4px}

/* ===== Messaging, QR handover, galleries, uploads (v13) ================ */

/* Header unread badge */
.nav-unread{display:inline-block;min-width:18px;padding:0 5px;height:18px;line-height:18px;font-size:11px;font-weight:800;text-align:center;color:#fff;background:var(--accent,#E8A33D);border-radius:999px;vertical-align:middle}

/* Listing message CTA */
.msg-cta-form{margin:0 0 8px}
.msg-note{font-size:14px;color:var(--muted);background:#f4f0e8;border-radius:var(--radius-sm);padding:10px 12px;margin:0 0 8px}

/* Gallery thumbnails */
.gallery-thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.gallery-thumb{width:74px;height:56px;border:2px solid transparent;border-radius:8px;background-size:cover;background-position:center;cursor:pointer;padding:0}
.gallery-thumb.active{border-color:var(--brand)}

/* Inbox list */
.msg-list{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.msg-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);text-decoration:none;color:var(--ink)}
.msg-item:hover{background:var(--brand-ll)}
.msg-item.msg-unread{background:#fbf6ec}
.msg-avatar{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:18px}
.msg-info{flex:1 1 auto;min-width:0}
.msg-name{font-weight:700;display:flex;align-items:center;gap:8px}
.msg-listing{font-size:13px;color:var(--brand-dk);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-preview{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-time{flex:0 0 auto;font-size:12px;color:var(--muted)}
.msg-unread-badge{display:inline-block;min-width:18px;padding:0 5px;height:18px;line-height:18px;font-size:11px;font-weight:800;text-align:center;color:#fff;background:#E8A33D;border-radius:999px}

/* Thread (conversation) */
.thread-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:6px 0 14px}
.thread-head h1{margin:0;font-size:22px}
.thread-listing{margin:4px 0 0;font-size:14px;color:var(--muted)}
.thread-listing a{color:var(--brand);text-decoration:underline}
.thread{display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto;padding:14px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius)}
.bubble{max-width:78%;padding:9px 13px;border-radius:14px;font-size:15px;line-height:1.45;word-wrap:break-word}
.bubble-mine{align-self:flex-end;background:var(--brand);color:#fff;border-bottom-right-radius:4px}
.bubble-theirs{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px}
.bubble-time{font-size:11px;opacity:.7;margin-top:3px;text-align:right}
.thread-reply{display:flex;gap:8px;margin-top:12px;align-items:flex-end}
.thread-reply textarea{flex:1 1 auto;resize:vertical;min-height:48px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font);font-size:15px}

/* QR panel */
.qr-wrap{margin:12px 0}
.qr-panel{text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;max-width:340px}
.qr-panel h3{margin:0 0 10px;font-size:16px;color:var(--brand-dk)}
.qr-code-img img{display:block;margin:0 auto;border-radius:8px}
.qr-help{font-size:13px;color:var(--muted);margin:10px 0 6px}
.qr-url{font-size:12px;word-break:break-all}
.qr-url a{color:var(--brand)}

/* Photo upload block on /ny */
.photo-upload{display:flex;flex-direction:column;gap:8px}
.photo-upload input[type=file]{padding:8px;border:1px dashed var(--line);border-radius:var(--radius-sm);background:#fff}
.mobile-photos,.mobile-thumbs{display:flex;flex-wrap:wrap;gap:8px}
.mobile-photos img,.mobile-thumbs img{width:90px;height:68px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}

/* Mobile handover pages (/m/...) */
.mobile-page{background:var(--bg)}
.mobile-wrap{max-width:520px;margin:0 auto;padding:18px 16px 40px}
.mobile-logo{display:flex;align-items:center;gap:7px;font-weight:800;color:var(--brand-dk);font-size:18px;margin-bottom:16px}
.mobile-wrap h1{font-size:24px;margin:0 0 6px}
.mobile-sub{color:var(--muted);font-size:14px;margin:0 0 16px}
.mobile-ok{background:#e6f2eb;color:var(--brand-dk);padding:10px 12px;border-radius:var(--radius-sm);font-weight:600}
.mobile-err{background:#fde8e8;color:#9b2c2c;padding:10px 12px;border-radius:var(--radius-sm)}
.mobile-upload-form{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.mobile-upload-form input[type=file]{padding:14px;border:1px dashed var(--line);border-radius:var(--radius-sm);background:#fff}
.mobile-thread{max-height:62vh}
.mobile-reply{flex-direction:column}
.mobile-reply textarea{width:100%}

/* Logo C: Poppins wordmark + headings (real web font) */
.logo-word,h1,h2,h3,h4,.section-title{font-family:'Poppins',var(--font)}
.logo-word{font-weight:800;letter-spacing:-1px}
/* Mobile: don't hide search — wrap it to a full-width second row */
@media(max-width:640px){
  .topbar-inner{flex-wrap:wrap;height:auto;padding:8px 0;gap:10px}
  .topsearch{display:flex;order:5;flex-basis:100%;max-width:none}
}

/* ---- Admin ---- */
.admin-stats{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:8px}
.admin-stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 22px;min-width:118px}
.admin-stat .n{display:block;font-size:28px;font-weight:800;color:var(--brand-dk)}
.admin-stat .l{color:var(--muted);font-size:13px}
.admin-note{color:var(--muted);margin:0 0 14px}
.logo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.logo-card{margin:0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.logo-frame{background:#F6F4EF;display:flex;align-items:center;justify-content:center;padding:14px;min-height:150px}
.logo-frame img{max-width:100%;max-height:150px}
.logo-card figcaption{padding:10px 12px;font-size:13px;color:var(--muted);border-top:1px solid var(--line)}

/* Contextual login prompt (coming from a sell flow / /ny) */
.auth-context{background:var(--brand-ll);color:var(--brand-dk);border:1px solid #cfe7d8;border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;margin:0 0 14px;line-height:1.5}

/* ---- Bedrift (business / enterprise) ---- */
.biz-hero{margin-top:8px}
.biz-lead{font-size:17px;line-height:1.6;color:var(--ink);max-width:62ch;margin:0 0 18px}
.biz-benefits{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:12px}
.biz-benefits li{background:var(--brand-ll);border:1px solid #cfe7d8;border-radius:var(--radius-sm);padding:12px 16px;line-height:1.5}
.biz-benefits strong{color:var(--brand-dk)}
.biz-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.biz-note{color:var(--muted);font-size:13px;line-height:1.5;margin:8px 0 0}
.biz-plan{color:var(--brand-dk);font-weight:700}
.biz-role{color:var(--muted);font-size:13px}
.auth-card-wide{max-width:560px}
.biz-orgnr-row{display:flex;gap:8px;align-items:stretch}
.biz-orgnr-row input{flex:1}
.biz-orgnr-status{display:block;font-size:13px;color:var(--muted);margin-top:6px;min-height:1em}
.biz-token-reveal code.biz-token-secret{display:block;margin-top:8px;padding:10px 12px;background:#0f2a1e;color:#d8f3e3;border-radius:var(--radius-sm);font-family:ui-monospace,Menlo,Consolas,monospace;word-break:break-all}
.biz-token-form{max-width:420px;margin-bottom:8px}
.btn-sm{padding:4px 10px;font-size:13px}
.api-pre{background:#0f2a1e;color:#d8f3e3;border-radius:var(--radius-sm);padding:14px 16px;overflow-x:auto;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;white-space:pre}

/* Firmaprofil on listing detail (org-attributed listings) */
.firma-profile{display:flex;gap:12px;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.firma-logo{width:48px;height:48px;border-radius:10px;object-fit:cover;flex:0 0 auto}
.firma-logo-ph{display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:800;font-size:22px}
.firma-name{font-weight:700;color:var(--ink)}
.firma-type{color:var(--muted);font-size:13px}
.firma-web{font-size:13px;color:var(--brand-dk);font-weight:600}

/* Business API token reveal: code + copy button */
.biz-token-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.biz-token-secret{flex:1 1 320px;word-break:break-all;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 10px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px}

/* ---- Varslinger (saved searches) + Premium --------------------------- */
.results-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.save-search{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.save-search input[type=text]{border:1.5px solid var(--line);border-radius:999px;padding:7px 14px;font-size:14px;font-family:inherit;min-width:170px;background:#fff;color:var(--ink)}
.save-search input[type=text]:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.save-search-login{font-size:13px;font-weight:600;color:var(--muted)}
.save-search-login:hover{color:var(--brand)}

.premium-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:linear-gradient(100deg,#fff6e6,#fdeecb);border:1px solid #f0d79a;border-radius:var(--radius);padding:16px 20px;margin-bottom:20px;font-size:15px;color:#6b4e16}

.saved-search-row{margin-bottom:16px}
.ss-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.ss-head h2{margin:0}
.ss-head h2 a{color:var(--ink)}
.ss-head h2 a:hover{color:var(--brand)}
.ss-view{font-size:13px;font-weight:600;color:var(--brand-dk);white-space:nowrap}
.ss-summary{color:var(--muted);font-size:14px;margin:6px 0 2px}
.ss-checked{color:var(--muted);font-size:12px;margin:0 0 12px}
.ss-toggles{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.toggle-btn{cursor:pointer;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;font-family:inherit;border:1.5px solid var(--line);background:#fff;color:var(--muted)}
.toggle-btn.on{border-color:var(--brand);background:var(--brand-ll);color:var(--brand-dk)}
.toggle-btn:hover{border-color:var(--brand)}
.ss-toggle-locked{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);padding:7px 0}
.ss-toggle-locked a{font-weight:700;color:#b8860b;text-decoration:underline}
.ss-rename,.phone-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.ss-rename input[type=text],.phone-form input{border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:7px 12px;font-size:14px;font-family:inherit;flex:1 1 220px;background:#fff;color:var(--ink)}
.ss-rename input[type=text]:focus,.phone-form input:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ll)}
.btn-text-danger{background:none;border:0;color:#a12525;font-weight:600;font-size:13px;cursor:pointer;padding:7px 4px;font-family:inherit}
.btn-text-danger:hover{text-decoration:underline}

.badge-premium{display:inline-block;font-size:13px;font-weight:700;padding:3px 11px;border-radius:999px;background:#E8A33D;color:#4a3300;vertical-align:middle}
.badge-premium-link{font-size:14px;font-weight:600;color:#b8860b;text-decoration:underline;vertical-align:middle}
.premium-card .premium-perks{list-style:none;padding:0;margin:0 0 16px}
.premium-card .premium-perks li{padding:6px 0;font-size:15px;border-bottom:1px solid var(--line)}
.premium-active{font-size:17px;font-weight:700;color:var(--brand-dk)}
.premium-note{color:var(--muted);font-size:13px;margin-top:14px}
.admin-premium-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.admin-premium-form input{border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;font-family:inherit;flex:1 1 240px}
.admin-premium-list{list-style:none;padding:0;margin:0;font-size:14px}
.admin-premium-list li{padding:4px 0;color:var(--muted)}

/* ---- Jobb (job search) ---- */
.flash-info{background:#fff8e8;border:1.5px solid #E8A33D;color:#5a4300;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px}
.job-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.job-card{display:block;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,box-shadow .15s}
.job-card:hover{border-color:var(--brand);box-shadow:0 4px 16px rgba(31,107,74,.08)}
.job-card-body{padding:16px}
.job-card .card-title{margin:6px 0 2px;font-size:16px}
.job-card .card-sub{color:var(--muted);font-size:13px;margin-bottom:8px}
.job-card-snippet{font-size:13px;color:var(--ink);margin:8px 0 6px;line-height:1.45}
.job-card-reason{font-size:12.5px;color:var(--brand-dk);background:var(--brand-ll);padding:7px 10px;border-radius:var(--radius-sm);margin:8px 0 0}
.job-badges{display:flex;flex-wrap:wrap;gap:5px;margin:6px 0}
.job-badge{font-size:11.5px;font-weight:600;padding:2px 9px;border-radius:999px;background:#f0ede3;color:#6a5a2e;border:1px solid #e0d8c2}
.job-score-chip{display:inline-block;font-size:13px;font-weight:800;padding:3px 11px;border-radius:999px;background:var(--brand);color:#fff;margin-bottom:8px}
.job-source-tag,.job-source-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px;background:#eef2f4;color:#555;letter-spacing:.02em}
.job-source-badge{margin-bottom:8px}
.job-source-finnting{background:var(--brand-ll);color:var(--brand-dk)}
.job-detail-head h1{margin:8px 0 2px}
.job-company{color:var(--muted);font-size:15px;margin:0 0 10px}
.job-deadline{font-size:14px;color:var(--ink);margin:10px 0}
.job-match-box{border-color:var(--brand);background:var(--brand-ll)}
.job-fulltext-note,.job-source-note{font-size:12.5px;color:var(--muted);font-style:italic;margin-top:8px}

/* Sold / withdrawn listing status */
.listing-status-banner{border-radius:var(--radius);padding:12px 18px;margin:0 0 18px;font-weight:700;font-size:15px}
.listing-status-banner.is-sold{background:#e6f2eb;color:var(--brand-dk);border:1px solid #b7ddc6}
.listing-status-banner.is-withdrawn{background:#f3eee3;color:#7a5b1e;border:1px solid #e3d4a8}
.sold-note{background:#f3f1ec;color:var(--muted);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;margin:0 0 10px}
.badge-sold{background:var(--brand-dk)!important;color:#fff!important}

/* ---- Mobile audit fixes ---- */
.spec td code{overflow-wrap:anywhere;word-break:break-word}      /* H2: /bedrift/api endpoint table */
.badge-feat,.badge-deal,.job-source-tag{font-size:12px}          /* L1: legibility floor */
@media(max-width:640px){
  /* H1: topnav was a non-wrapping flex row → horizontal scroll on logged-in pages + /admin */
  .topnav{flex-wrap:wrap;margin-left:0;width:100%;gap:8px;justify-content:flex-start}
  .topnav .btn-primary{flex:1 1 100%;justify-content:center}     /* full-width CTA */
  .topnav-link{min-height:40px;display:inline-flex;align-items:center;padding:6px 4px}  /* M2 tap targets */
  .catnav-link{min-height:40px;display:inline-flex;align-items:center}
  .topsearch button{min-width:44px}
  .hero-tabs{flex-wrap:wrap}                                     /* M1: hero tabs pill */
}
.admin-subtitle{font-size:15px;font-weight:700;color:#13452F;margin:22px 0 10px;letter-spacing:-.2px}
/* AI-generated demo listing markers — discreet, findable on inspection */
.card-ai{margin-top:6px;font-size:11px;color:#9a978f;letter-spacing:.2px;opacity:.85}
.ai-demo-note{margin-top:14px;font-size:13px;color:#8d8a82;border-top:1px solid #ece9e2;padding-top:10px}

/* ---- UX review fixes (2026-06-27) ---- */
/* Mobile-collapsible filter panel: toggle button hidden on desktop, panel always shown.
   The .js gate means no-JS users still see the full panel (never trapped behind a dead button). */
.filter-toggle{display:none}
.save-search-hint{display:block;font-size:12px;color:var(--muted);margin-top:4px}
@media(max-width:900px){
  .js .filter-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
    min-height:46px;padding:10px 16px;border:1px solid var(--line,#ddd);border-radius:10px;
    background:#fff;font-weight:700;color:var(--ink);cursor:pointer}
  .js .filter-toggle .filter-toggle-caret{transition:transform .15s}
  .js .filter-toggle[aria-expanded="true"] .filter-toggle-caret{transform:rotate(180deg)}
  .js #filterForm.filters{display:none;margin-top:10px}
  .js #filterForm.filters.is-open{display:flex}
}
/* Favourite heart: keep the 34px visual circle, expand the tap target to 44px (mobile comfort). */
.fav-btn::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%}
/* Facility checkboxes inside the post form rendered as centered columns (.adform label
   forces flex-direction:column) — restore the intended left-aligned row. */
.adform label.fac-check{flex-direction:row;align-items:center}

/* ---- UX review fixes batch 2 (2026-06-27) ---- */
/* Post-ad photo picker: hide native input, styled drop-zone + thumbnails */
.file-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.photo-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:22px 16px;border:2px dashed var(--line,#cfcabd);border-radius:12px;background:#fafaf7;
  cursor:pointer;text-align:center;transition:border-color .15s,background .15s}
.photo-dropzone:hover{border-color:var(--brand,#1F6B4A);background:#f3f7f4}
.photo-dropzone.is-drag{border-color:var(--brand,#1F6B4A);background:#eef5f0}
.photo-dz-icon{font-size:26px}
.photo-dz-text{font-weight:600;color:var(--ink)}
.photo-dz-link{color:var(--brand,#1F6B4A);text-decoration:underline}
.photo-dz-hint{font-size:12px;color:var(--muted)}
.photo-preview{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 0}
.photo-preview .photo-thumb{width:84px;height:84px;border-radius:8px;overflow:hidden;border:1px solid var(--line,#ddd);background:#fff}
.photo-preview .photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* QR copy fallback button */
.qr-copy{margin-top:6px;background:none;border:0;color:var(--brand,#1F6B4A);font-size:13px;text-decoration:underline;cursor:pointer;padding:4px}
/* API docs: copy button + horizontal-scroll fade hint */
.api-pre-wrap{position:relative}
.api-pre-wrap .api-pre.is-scrollable{-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent);mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent)}
.api-copy{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.92);border:1px solid var(--line,#ccc);
  border-radius:6px;font-size:12px;padding:4px 9px;cursor:pointer;color:var(--ink);min-height:28px;z-index:1}
.api-copy:hover{background:#fff}
/* API endpoints table: keep path identifiers from wrapping mid-token */
.api-table td code{white-space:nowrap}
.api-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* Collapsible form sections (Eiendom post form) */
.form-section{border:1px solid var(--line);border-radius:10px;margin:0 0 12px;background:#fff}
.form-section>summary{cursor:pointer;padding:12px 16px;font-weight:700;color:var(--brand-dk,#13452F);list-style:none;display:flex;align-items:center;justify-content:space-between;min-height:46px}
.form-section>summary::-webkit-details-marker{display:none}
.form-section>summary::after{content:"\25BE";color:var(--muted);transition:transform .15s}
.form-section[open]>summary::after{transform:rotate(180deg)}
.form-section>summary:hover{background:#fafaf7}
.form-section .adform-grid,.form-section .facilities-filter{padding:0 16px 16px}
.form-section-opt{font-weight:500;color:var(--muted);font-size:13px}

/* finn-style key-spec strip on listing detail */
.keyspec{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0;padding:0}
.keyspec li{flex:1 1 0;min-width:120px;display:flex;flex-direction:column;align-items:flex-start;
  gap:2px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:10px}
.keyspec-ic{font-size:18px;line-height:1}
.keyspec-val{font-weight:800;font-size:16px;color:var(--ink)}
.keyspec-lab{font-size:12px;color:var(--muted)}
@media(max-width:640px){ .keyspec li{flex:1 1 calc(50% - 10px)} }
