/* Värderingsinstitutet — ljus institutionell palett i logotypens anda */
:root{
  --bg:#faf6ee;
  --bg-soft:#f1ebde;
  --surface:#ffffff;
  --ink:#1e1711;
  --ink-muted:#5a4d42;
  --ink-dim:#8a7e72;
  --accent:#c8451a;
  --accent-dark:#a03612;
  --accent-ink:#ffffff;
  --rule:#d9cfb9;
  --rule-strong:#b6a98f;
  --serif:"Cormorant Garamond","EB Garamond",Georgia,serif;
  --sans:"Inter Tight","Helvetica Neue",system-ui,sans-serif;
  --maxw:1280px;
  --pad:clamp(20px,4vw,56px);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-0.01em;margin:0;line-height:1.1}
.display{font-size:clamp(44px,6.2vw,88px);line-height:1.02;letter-spacing:-0.02em}
.h2{font-size:clamp(34px,4.2vw,56px);line-height:1.05}
.h3{font-size:clamp(24px,2.4vw,32px);line-height:1.15}
.eyebrow{font-family:var(--sans);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
.lede{font-size:clamp(17px,1.35vw,20px);color:var(--ink-muted);max-width:62ch;line-height:1.55}

/* Header */
.header{position:sticky;top:0;z-index:40;background:rgba(250,246,238,0.88);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--rule)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{height:44px;width:auto;display:block}
.brand-sub{font-family:var(--sans);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-dim);border-left:1px solid var(--rule);padding-left:14px;line-height:1.35}
.nav{display:flex;align-items:center;gap:34px;font-size:14px}
.nav a{color:var(--ink-muted);transition:color .2s}
.nav a:hover,.nav a.active{color:var(--ink)}
.nav a.active{position:relative}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--accent)}
.nav-cta{border:1px solid var(--accent);color:var(--accent);padding:10px 18px;font-size:13px;letter-spacing:0.08em;text-transform:uppercase;font-weight:500;transition:background .2s,color .2s}
.nav-cta:hover{background:var(--accent);color:var(--accent-ink)}
.menu-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer}

/* Hero */
.hero{position:relative;padding:clamp(60px,8vw,120px) 0;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(1200px 500px at 80% -10%,rgba(200,69,26,0.08),transparent 60%),radial-gradient(800px 400px at -10% 110%,rgba(200,69,26,0.05),transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.15fr 0.85fr;gap:clamp(32px,5vw,80px);align-items:center;position:relative}
.hero h1{margin:18px 0 24px}
.hero h1 .accent{font-style:italic;color:var(--accent)}
.hero-ctas{display:flex;gap:16px;margin-top:36px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;font-size:14px;letter-spacing:0.08em;text-transform:uppercase;font-weight:500;transition:all .2s;cursor:pointer;border:0;font-family:var(--sans)}
.btn-primary{background:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.hero-image{position:relative;aspect-ratio:4/5;background-size:cover;background-position:center;border:1px solid var(--rule)}
.hero-image::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,23,17,0) 55%,rgba(30,23,17,0.55))}
.hero-badge{position:absolute;bottom:24px;left:24px;right:24px;display:flex;justify-content:space-between;align-items:end;color:#fff;font-size:13px;z-index:2}
.hero-badge-num{font-family:var(--serif);font-size:56px;line-height:1;color:#fff;font-style:italic}
.hero-badge-label{max-width:180px;letter-spacing:0.02em;line-height:1.35}
.hero-meta{position:absolute;top:0;right:var(--pad);display:flex;gap:24px;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);padding-top:clamp(30px,5vw,60px)}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta span::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%}

section{padding:clamp(60px,7vw,100px) 0;position:relative}
.section-head{margin-bottom:clamp(36px,5vw,64px);max-width:720px}
.section-head.centered{margin-left:auto;margin-right:auto;text-align:center}
.section-head.centered .eyebrow{justify-content:center;display:flex}
.section-head h2{margin-top:18px}
.section-head .lede{margin-top:16px}

/* Trust */
.trust{background:var(--bg-soft);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:56px 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.trust-item{display:flex;flex-direction:column;gap:8px;border-left:1px solid var(--rule);padding-left:24px}
.trust-item:first-child{border-left:0;padding-left:0}
.trust-label{font-family:var(--serif);font-size:42px;color:var(--accent);line-height:1;font-style:italic}
.trust-label.short{font-style:normal;font-size:28px}
.trust-body{font-size:14px;color:var(--ink-muted);line-height:1.5}

/* Specialty */
.specialty{background:var(--bg)}
.specialty-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.specialty-card{background:var(--bg);padding:44px 40px;display:flex;flex-direction:column;gap:14px;transition:background .3s;position:relative;color:inherit;text-decoration:none}
.specialty-card:hover{background:var(--bg-soft)}
.specialty-num{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:20px;letter-spacing:0.08em}
.specialty-card h3{font-size:30px}
.specialty-card p{color:var(--ink-muted);margin:0;max-width:44ch}
.specialty-card .arrow{position:absolute;top:40px;right:40px;width:32px;height:32px;border:1px solid var(--rule-strong);display:grid;place-items:center;color:var(--accent);transition:border-color .2s,background .2s,color .2s}
.specialty-card:hover .arrow{border-color:var(--accent);background:var(--accent);color:#fff}

/* Services */
.services{background:var(--bg-soft)}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service-card{background:var(--surface);border:1px solid var(--rule);display:flex;flex-direction:column;transition:transform .3s,border-color .3s,box-shadow .3s}
.service-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 16px 32px -20px rgba(30,23,17,0.25)}
.service-image{aspect-ratio:4/3;background-size:cover;background-position:center;border-bottom:1px solid var(--rule)}
.service-image.placeholder{background:linear-gradient(135deg,#3a5a40,#1e3a28);display:grid;place-items:center;color:#c9bfb1;font-family:var(--serif);font-style:italic;font-size:18px;text-align:center;padding:24px}
.image-credit{font-size:11px;color:var(--ink-muted);opacity:0.7;margin-top:auto;padding-top:8px;font-style:italic}
.image-credit a{color:inherit;text-decoration:underline;text-decoration-color:var(--rule)}
.image-credit a:hover{text-decoration-color:var(--accent)}
.service-body{padding:28px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.service-body h3{font-size:22px;color:var(--ink)}
.service-body p{font-size:14.5px;color:var(--ink-muted);margin:0;flex:1}
.service-more{margin-top:12px;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:8px}

/* About */
.about{background:var(--bg);position:relative}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.about-image{aspect-ratio:4/5;background-size:cover;background-position:center;border:1px solid var(--rule);position:relative}
.about-image::before{content:"";position:absolute;inset:-1px;border:1px solid var(--accent);transform:translate(16px,16px);z-index:-1}
.about-text h2{margin-bottom:20px}
.about-text p{color:var(--ink-muted);font-size:17px;max-width:58ch}
.quote{margin-top:40px;padding-top:32px;border-top:1px solid var(--rule);font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.4;color:var(--ink);max-width:58ch}
.quote-author{margin-top:20px;font-family:var(--sans);font-style:normal;font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-dim)}

/* Contact */
.contact{background:var(--bg-soft)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.contact-info{display:flex;flex-direction:column;gap:28px}
.info-card{padding:28px 0;border-top:1px solid var(--rule)}
.info-card:first-of-type{border-top:1px solid var(--rule-strong)}
.info-label{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:10px}
.info-card h4{font-family:var(--serif);font-size:26px;margin-bottom:4px;font-style:italic;color:var(--accent)}
.info-card .num{font-family:var(--serif);font-size:34px;color:var(--ink)}
.info-card .num.small{font-size:22px;color:var(--ink-muted);margin-top:4px}
.info-card address{font-style:normal;color:var(--ink-muted);line-height:1.6}

.form{background:var(--surface);border:1px solid var(--rule);padding:clamp(28px,3vw,40px)}
.form h3{font-family:var(--serif);font-size:28px;margin-bottom:8px}
.form p.help{color:var(--ink-dim);font-size:14px;margin:0 0 24px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-dim)}
.field input,.field select,.field textarea{background:transparent;border:0;border-bottom:1px solid var(--rule-strong);color:var(--ink);font-family:var(--sans);font-size:15px;padding:10px 0;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .btn{margin-top:8px}

/* Footer */
.footer{background:#1e1711;color:#e8dfd2;border-top:4px solid var(--accent);padding:72px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:60px;margin-bottom:56px}
.footer h4{font-family:var(--serif);font-size:18px;margin-bottom:18px;font-style:italic;color:#f4a582}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:#c9bfb1}
.footer a:hover{color:#f4a582}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;display:flex;justify-content:space-between;font-size:12px;color:#8a7e72;letter-spacing:0.08em;text-transform:uppercase}

/* Page header (subpages) */
.page-header{padding:clamp(80px,10vw,140px) 0 clamp(40px,5vw,60px);border-bottom:1px solid var(--rule);background:radial-gradient(800px 300px at 20% 0%,rgba(200,69,26,0.06),transparent 60%),var(--bg)}
.page-header .eyebrow{margin-bottom:18px}
.page-header h1{font-size:clamp(40px,5vw,72px)}
.page-header .lede{margin-top:20px}

/* Prose (text-only pages) */
.prose{padding:clamp(50px,7vw,90px) 0;max-width:760px}
.prose h2{font-size:32px;margin:44px 0 16px;color:var(--accent);font-style:italic;font-family:var(--serif)}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:22px;margin:28px 0 10px;font-family:var(--serif)}
.prose p,.prose li{color:var(--ink-muted);font-size:17px;line-height:1.7}
.prose ul{padding-left:18px}
.prose li{margin-bottom:8px}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{text-decoration-thickness:2px}

/* News */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news-card{border:1px solid var(--rule);padding:28px;background:var(--surface);display:flex;flex-direction:column;gap:14px;transition:border-color .2s,box-shadow .2s}
.news-card:hover{border-color:var(--accent);box-shadow:0 16px 32px -20px rgba(30,23,17,0.2)}
.news-date{font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.news-card h3{font-size:22px;line-height:1.25;font-family:var(--serif)}
.news-card p{color:var(--ink-muted);font-size:14.5px;margin:0}
.news-more{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);margin-top:auto;font-weight:600}

/* Env-badge (dev) */
.env-badge{position:fixed;bottom:16px;right:16px;background:var(--accent);color:#fff;padding:8px 14px;font-family:var(--sans);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;z-index:1000;box-shadow:0 2px 12px rgba(30,23,17,0.25)}

/* Responsive */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr}
  .hero-image{aspect-ratio:4/3;order:-1}
  .hero-meta{display:none}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:28px 24px}
  .trust-item{border-left:0;padding-left:0;border-top:1px solid var(--rule);padding-top:20px}
  .trust-item:first-child,.trust-item:nth-child(2){border-top:0;padding-top:0}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .specialty-grid{grid-template-columns:1fr}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .news-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
}
@media (max-width:640px){
  .nav:not(.is-open){display:none}
  .menu-toggle{display:block}
  .services-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:10px}
}
