/* Cypern Fastigheter — shared stylesheet. Tokens from Project docs/design/DESIGN-TOKENS.md.
   Served as a static asset (/styles.css). Self-hosted fonts (no Google Fonts). */

/* ---- self-hosted fonts ---- */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400 600;font-display:swap;src:url('/fonts/fraunces-wght.woff2') format('woff2')}
@font-face{font-family:'Sora';font-style:normal;font-weight:400 600;font-display:swap;src:url('/fonts/sora-wght.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/space-mono-400.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/space-mono-700.woff2') format('woff2')}

:root{
  --bg:#FAF4E9; --surface:#FFFDF8; --ink:#173A3D; --ink-soft:#7A7264; --line:#EAE0CE;
  --sea:#15B5A6; --sea-deep:#0F8E84; --sun:#E89C28; --sun-deep:#9A6310; --terracotta:#C7613C;
  /* Darker teal for TEXT/interactive — WCAG AA (≥4.5:1): white-on-teal buttons + teal links.
     --sea stays for decorative borders/accents (non-text / large, where AA is relaxed). */
  --sea-ink:#0C7E72; --sea-ink-deep:#095F56;
  --radius:14px; --radius-sm:9px; --maxw:1080px;
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-num:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--sea-ink);text-decoration:none}
a:hover{text-decoration:underline}
/* WCAG 1.4.1: links inside text blocks must not rely on colour alone → underline them. */
.prose a,.desc a,main p a,main li a,.summary a,.compare td a,.faq .a a,.region-intro a{text-decoration:underline}
img{max-width:100%;display:block}
:focus-visible{outline:3px solid var(--sea);outline-offset:2px;border-radius:3px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 var(--radius-sm) 0;z-index:10}
.skip:focus{left:0}

/* header */
header.site{border-bottom:1px solid var(--line);background:var(--surface)}
.site .wrap{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:16px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--ink)}
.logo .gl{flex-shrink:0}
nav.site a{color:var(--ink-soft);font-size:15px;margin-left:24px}
nav.site a:hover{color:var(--ink)}
/* CSS-only mobile menu (no JS): burger hidden on desktop; below 720px the nav collapses
   into a tap-friendly column toggled by the hidden checkbox. */
.nav-burger{display:none}
@media(max-width:720px){
  .nav-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;cursor:pointer;margin-left:auto}
  .nav-burger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;margin:0 auto;transition:transform .2s,opacity .2s}
  nav.site{display:none;flex-basis:100%;flex-direction:column;gap:0;margin-top:4px}
  nav.site a{margin-left:0;padding:13px 4px;font-size:16px;border-top:1px solid var(--line)}
  .nav-toggle:checked~nav.site{display:flex}
  .nav-toggle:checked~.nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked~.nav-burger span:nth-child(2){opacity:0}
  .nav-toggle:checked~.nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* breadcrumb */
.crumbs{font-size:13px;color:var(--ink-soft);padding:16px 0 0}
.crumbs a{color:var(--ink-soft)}
.crumbs .sep{margin:0 6px;opacity:.5}

/* title block */
.titleblock{padding:8px 0 20px}
.titleblock h1{font-family:var(--font-display);font-size:34px;font-weight:600;letter-spacing:-.01em;line-height:1.12}
.titleblock .loc{color:var(--ink-soft);font-size:16px;margin-top:4px}
.badges{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.badge{font-size:12.5px;font-weight:500;padding:4px 10px;border-radius:999px;background:#DBF3F0;color:#0C6E66}
.badge.sun{background:#FBEAC9;color:var(--sun-deep)}

/* gallery */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:140px 140px;gap:8px;border-radius:var(--radius);overflow:hidden}
.gallery .ph{position:relative;display:block;background:linear-gradient(135deg,#bfe3df,#e9cfa0);overflow:hidden;cursor:zoom-in}
.gallery .ph img{width:100%;height:100%;object-fit:cover;display:block}
.gallery .ph:first-child{grid-row:1 / span 2}
.gallery .more{position:absolute;right:8px;bottom:8px;font-size:12px;background:rgba(23,58,61,.82);color:#fff;padding:4px 10px;border-radius:6px}
@media(max-width:860px){.gallery{grid-template-columns:1fr 1fr;grid-template-rows:120px 120px}}
/* overflow images: present in HTML, revealable without JS */
.more-images{margin-top:10px}
.more-images>summary{cursor:pointer;font-size:14px;color:var(--sea);list-style:none}
.more-images>summary::-webkit-details-marker{display:none}
.more-images[open]>summary{margin-bottom:10px}
.more-images .grid-rest{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
.more-images .grid-rest .rest-ph{display:block;cursor:zoom-in}
.more-images .grid-rest img{border-radius:var(--radius-sm);aspect-ratio:3/2;object-fit:cover;width:100%;display:block}

/* CSS-only lightbox (no JS): hidden until its #lb-N is the :target */
.lightbox{display:none;position:fixed;inset:0;z-index:1000;background:rgba(12,20,22,.93);align-items:center;justify-content:center}
.lightbox:target{display:flex}
.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:6px;box-shadow:0 14px 44px rgba(0,0,0,.5);position:relative;z-index:1}
.lb-backdrop{position:absolute;inset:0;cursor:zoom-out}
.lb-close{position:absolute;top:12px;right:22px;color:#fff;font-size:34px;line-height:1;text-decoration:none;z-index:2;opacity:.85}
.lb-close:hover{opacity:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:54px;line-height:1;text-decoration:none;padding:8px 20px;z-index:2;opacity:.8;user-select:none}
.lb-nav:hover{opacity:1}
.lb-prev{left:4px}.lb-next{right:4px}
.lb-count{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.45);padding:3px 11px;border-radius:20px;z-index:2}
@media(max-width:860px){.lb-nav{font-size:40px;padding:6px 12px}.lightbox img{max-width:96vw}}

/* layout */
.grid{display:grid;grid-template-columns:1fr 320px;gap:32px;padding:28px 0 64px;align-items:start}
@media(max-width:860px){.grid{grid-template-columns:1fr}}
section.block{margin-bottom:32px}
h2{font-family:var(--font-display);font-size:21px;font-weight:600;letter-spacing:-.01em;margin-bottom:14px}

/* facts table */
.facts{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.facts .row{display:flex;justify-content:space-between;gap:16px;padding:13px 18px;border-bottom:1px solid var(--line);font-size:15px}
.facts .row:last-child{border-bottom:none}
.facts .row .k{color:var(--ink-soft)}
.facts .row .v{font-weight:600;text-align:right}
.facts .num{font-family:var(--font-num);font-weight:400;font-variant-numeric:tabular-nums}

/* description */
.desc{font-size:16px;color:#3a342b;line-height:1.7}

/* freehold reassurance — signature trust block */
.reassure{background:#FBEAC9;border:1px solid #F0D79A;border-radius:var(--radius);padding:16px 18px;display:flex;gap:12px;align-items:flex-start}
.reassure .ic{font-size:18px;line-height:1.4;color:var(--sun-deep)}
.reassure .t{font-size:14.5px;color:#6b5526}
.reassure .t b{color:#5a3f12;font-weight:600}

/* rental block (conditional) */
.rental{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rental .row{display:flex;justify-content:space-between;gap:16px;padding:13px 18px;border-bottom:1px solid var(--line);font-size:15px}
.rental .row:last-child{border-bottom:none}
.rental .k{color:var(--ink-soft)}
.rental .k .tag{display:inline-block;font-size:11px;font-weight:600;padding:1px 7px;border-radius:999px;margin-left:6px;vertical-align:middle}
.rental .tag.guar{background:#DBF3F0;color:#0C6E66}
.rental .tag.proj{background:#F2EAD9;color:var(--sun-deep)}
.rental .v{font-weight:600;font-family:var(--font-num);font-variant-numeric:tabular-nums}
.rental .note{padding:11px 18px;font-size:12.5px;color:var(--ink-soft);background:#FBF7EE}

/* sidebar / price-card */
.side{position:sticky;top:20px;display:flex;flex-direction:column;gap:16px}
.price-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.price-card .price{font-family:var(--font-display);font-size:32px;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.price-card .vat{font-size:13px;color:var(--ink-soft);margin-top:2px}
.price-card .ppm{font-size:13px;color:var(--ink-soft);margin-top:8px;font-family:var(--font-num)}
.cta{display:block;width:100%;background:var(--sea-ink);color:#fff;text-align:center;font-size:16px;font-weight:600;padding:13px;border-radius:var(--radius-sm);margin-top:16px;border:none;cursor:pointer;font-family:var(--font-sans)}
.cta:hover{background:var(--sea-ink-deep);text-decoration:none}
.consent{display:flex;gap:8px;align-items:flex-start;margin-top:14px;font-size:12.5px;color:var(--ink-soft)}
.consent input{margin-top:3px;flex-shrink:0;accent-color:var(--sea)}
.cta-note{font-size:12px;color:var(--ink-soft);margin-top:10px;line-height:1.5}
.provenance{font-size:12px;color:var(--ink-soft);padding:14px 0 0;border-top:1px solid var(--line);margin-top:14px}

/* listing cards (hub grids + "Liknande bostäder") */
.card-grid,.similar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.scard{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;color:var(--ink)}
.scard:hover{text-decoration:none;border-color:var(--sea)}
.scard .img{aspect-ratio:3/2;background:linear-gradient(135deg,#bfe3df,#e9cfa0);overflow:hidden}
.scard .img img{width:100%;height:100%;object-fit:cover}
.scard .body{padding:12px 14px}
.scard .p{font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.scard .loc{font-size:13px;color:var(--ink-soft);margin-top:2px}
.scard .m{font-size:13px;color:var(--ink);margin-top:6px;font-variant-numeric:tabular-nums}
.scard .cbadge{margin-top:10px}

/* amenities chip block (Bekvämligheter) */
.amenities{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:13px;font-weight:500;padding:5px 12px;border-radius:999px;background:#DBF3F0;color:#0C6E66;border:1px solid #BFE6E0}

/* hub header + filters + empty state + FAQ */
.hub-head{padding:8px 0 22px}
.byline{font-size:13px;color:var(--ink-soft);margin:6px 0 0}
.region-intro{font-size:16px;color:#3a342b;line-height:1.7;margin:4px 0 16px;max-width:680px}
.region-stats{margin:0 0 20px;max-width:560px}
.hub-head h1{font-family:var(--font-display);font-size:32px;font-weight:600;letter-spacing:-.01em;line-height:1.14}
.hub-head .sub{color:var(--ink-soft);font-size:16px;margin-top:6px}
.filter-chips{margin:18px 0 4px;display:flex;flex-wrap:wrap;gap:8px}
.filter-chips a{font-size:14px;padding:6px 13px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--ink)}
.filter-chips a:hover{border-color:var(--sea);text-decoration:none}
.filter-chips a[aria-current="page"]{background:var(--sea);color:#fff;border-color:var(--sea)}
.hub-section{padding:24px 0 56px}
.empty{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;color:var(--ink-soft)}
.empty a{font-weight:500}
.faq{margin-top:40px}
.faq details{border-bottom:1px solid var(--line);padding:14px 0}
.faq summary{font-family:var(--font-display);font-size:17px;font-weight:600;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq details[open] summary{margin-bottom:8px}
.faq .a{color:#3a342b;font-size:15px;line-height:1.7}
.crosslinks{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);font-size:14px;display:flex;flex-wrap:wrap;gap:8px 20px}

/* comparison (authority) page */
.verdict{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
@media(max-width:680px){.verdict{grid-template-columns:1fr}}
.verdict .vcol{border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;background:var(--surface)}
.verdict .vcol-a{border-left:4px solid var(--sea)}
.verdict .vcol-b{border-left:4px solid var(--sun)}
.verdict h3{font-family:var(--font-display);font-size:16px;margin-bottom:10px}
.verdict ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.verdict li{font-size:14px;padding-left:18px;position:relative;line-height:1.5}
.verdict li::before{content:"›";position:absolute;left:2px;color:var(--sea);font-weight:700}
.verdict .vcol-b li::before{color:var(--sun-deep)}
.compare{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.compare table{border-collapse:collapse;width:100%;font-size:14.5px}
.compare th,.compare td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.compare thead th{font-family:var(--font-display);font-weight:600;font-size:15px;background:#FBF7EE;position:sticky;top:0}
.compare tbody th{font-weight:600;color:var(--ink);width:21%}
.compare td{color:#3a342b}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:none}
.compare .ref a{font-size:11px;color:var(--sea)}
.table-notes{font-size:12.5px;color:var(--ink-soft);margin-top:12px;line-height:1.6}
.disclaimer{background:#FBEAC9;border:1px solid #F0D79A;border-radius:var(--radius);padding:16px 18px;font-size:14px;color:#6b5526;margin:32px 0}
.sources{font-size:13px;color:var(--ink-soft);padding-left:22px;display:flex;flex-direction:column;gap:6px}
.sources a{color:var(--sea)}
.updated{font-size:12px;color:var(--ink-soft);margin-top:12px}
.cta-block{margin-top:40px;padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.cta-block h2{margin-bottom:14px}

/* homepage hero */
.hero{background:linear-gradient(160deg,#FBEAC9 0%,var(--bg) 42%,#DBF3F0 100%);border-bottom:1px solid var(--line)}
.hero .wrap{padding:56px 24px 48px;text-align:center}
.hero-gl{margin:0 auto 14px}
.hero h1{font-family:var(--font-display);font-size:40px;font-weight:600;letter-spacing:-.02em;line-height:1.08}
@media(max-width:560px){.hero h1{font-size:30px}}
.lede{color:var(--ink-soft);font-size:18px;max-width:620px;margin:12px auto 0;line-height:1.6}
.hero-cta{margin-top:24px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;background:var(--sea-ink);color:#fff;font-weight:600;font-size:16px;padding:12px 22px;border-radius:var(--radius-sm)}
.btn:hover{background:var(--sea-ink-deep);text-decoration:none}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--surface);border-color:var(--sea)}

/* homepage trust row */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0 64px}
@media(max-width:680px){.trust{grid-template-columns:1fr}}
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.tcard h3{font-family:var(--font-display);font-size:17px;margin-bottom:8px}
.tcard p{font-size:14px;color:var(--ink-soft);line-height:1.6}

/* form pages (kontakt, integritetspolicy) */
.formpage{max-width:620px;margin:0 auto;padding:40px 0 64px}
.formpage h1{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-.01em;margin-bottom:6px}
.formpage h2{font-family:var(--font-display);font-size:18px;margin:22px 0 6px}
.prose p{font-size:15px;color:#3a342b;line-height:1.7;margin-bottom:8px}
.lead-form{display:flex;flex-direction:column;gap:14px;margin-top:24px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.lead-form label{display:flex;flex-direction:column;gap:5px;font-size:14px;color:var(--ink-soft)}
.lead-form input[type=text],.lead-form input[name=name],.lead-form input[type=tel],.lead-form input[type=email]{font-family:var(--font-sans);font-size:16px;padding:11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink)}
.consent-row{flex-direction:row!important;align-items:flex-start;gap:10px;font-size:13px;color:var(--ink-soft);line-height:1.5}
.consent-row input{margin-top:3px;flex-shrink:0;accent-color:var(--sea)}
.lead-form .cta{cursor:pointer}
.form-error{background:#FBEAC9;border:1px solid #F0D79A;color:#6b5526;padding:11px 14px;border-radius:var(--radius-sm);font-size:14px;margin-top:16px}

/* reference/guide articles */
.article{max-width:780px;margin:0 auto;padding-bottom:56px}
.article .block h2{margin-top:8px}

/* footer */
footer.site{border-top:1px solid var(--line);background:var(--surface);margin-top:48px;color:var(--ink-soft)}
.fwrap{max-width:var(--maxw);margin:0 auto;padding:36px 24px;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:28px}
.fcol{display:flex;flex-direction:column;gap:9px}
.fcol .ftitle{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:2px}
.fcol a{color:var(--ink-soft);font-size:14px}
.fcol a:hover{color:var(--ink)}
.fcol .fnote{font-size:13px;line-height:1.6;max-width:42ch;margin:0}
@media(max-width:680px){.fwrap{grid-template-columns:1fr 1fr;gap:24px}.fcol-about{grid-column:1/-1}}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* köpkostnadskalkylator (the one interactive tool) */
.calc-form{display:flex;flex-wrap:wrap;gap:14px;margin:14px 0 18px}
.calc-form label{display:flex;flex-direction:column;gap:5px;font-size:14px;color:var(--ink-soft)}
.calc-form input,.calc-form select{font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);min-width:170px}
.calc-result{margin-top:4px}
.calc .muted{color:var(--ink-soft);font-weight:400;font-size:12.5px}
