/* Kaffeeleidenschaft Berlin — shared styles */
:root{
  /* Espresso/Copper palette – matches the premium single-file design */
  --ink:        #0E0906;
  --brown:      #3A2214;
  --brown-d:    #2A180D;
  --orange:     #B5551E;
  --orange-deep:#8F3F12;
  --cream:      #F8F3EB;
  --tan:        #E5DAC5;
  --bg:         #EFE7D4;
  --muted:      #7E6550;

  /* Extra tokens for richer use */
  --copper:     #B5551E;
  --copper-lt:  #D47A45;
  --gold:       #C8A456;
  --mahogany:   #1C100A;
  --ivory:      #F8F3EB;
  --milk:       #FCF9F5;
  --parchment:  #E5DAC5;
  --brd:        rgba(107,63,34,.13);

  /* Shadows */
  --sh1: 0 1px 4px rgba(14,9,6,.06);
  --sh2: 0 4px 16px rgba(14,9,6,.10);
  --sh3: 0 12px 48px rgba(14,9,6,.16);
  --sh4: 0 24px 80px rgba(14,9,6,.22);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink);font-family:"DM Sans",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.serif{font-family:"Instrument Serif",Georgia,serif;font-weight:400;letter-spacing:-.01em;line-height:1.02;}
.serif i{font-style:italic;}
.mono{font-family:"Space Mono",ui-monospace,monospace;text-transform:uppercase;letter-spacing:.16em;}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px;}
.narrow{max-width:820px;}

.btn{display:inline-flex;align-items:center;gap:8px;background:var(--copper);color:#fff;border:none;
  font-family:inherit;font-weight:700;font-size:16px;padding:16px 28px;border-radius:44px;cursor:pointer;
  transition:background .15s,transform .15s;}
.btn:hover{background:var(--orange-deep);transform:translateY(-1px);}
.btn.ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(255,255,255,.32);}
.btn.ghost:hover{background:rgba(255,255,255,.1);}
.btn.line{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn.line:hover{background:var(--ink);color:var(--cream);}

/* utility bar */
.util{background:rgba(14,9,6,1);color:rgba(248,243,235,.6);font-size:13.5px;}
.util .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap;}
.util .r{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.util a:hover{color:#fff;}
.util .shop{color:var(--copper-lt);font-weight:600;}

/* nav */
header.nav{position:sticky;top:0;z-index:50;
  background:rgba(14,9,6,.96);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid rgba(248,243,235,.06);
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:20px;}
.logo{display:flex;align-items:center;gap:12px;font-family:"Instrument Serif",serif;font-size:26px;}
.logo .mark{width:30px;height:30px;border-radius:50%;background:var(--brown);position:relative;flex:none;}
.logo .mark::after{content:"";position:absolute;inset:8px;border-radius:50%;background:var(--copper);}
.links{display:flex;gap:4px;align-items:center;}
.links a{font-size:14px;font-weight:500;color:rgba(248,243,235,.55);
  padding:.4rem .7rem;border-radius:4px;transition:color .18s,background .18s;}
.links a:hover{color:rgba(248,243,235,1);}
.links a.active{color:rgba(248,243,235,1);background:rgba(248,243,235,.09);}
.nav .cta{display:flex;align-items:center;gap:14px;}
.nav .cta .btn.line{background:transparent;color:rgba(248,243,235,.85);
  border-color:rgba(248,243,235,.3);}
.nav .cta .btn.line:hover{background:rgba(248,243,235,.1);color:rgba(248,243,235,1);
  border-color:rgba(248,243,235,.6);}

section{padding:84px 0;}
.eye{display:inline-flex;align-items:center;gap:10px;font-size:12px;color:var(--orange-deep);margin-bottom:18px;}
.eye .dot{width:7px;height:7px;border-radius:50%;background:var(--copper);}
.sec-head{text-align:center;max-width:680px;margin:0 auto 52px;}
.sec-head h2{font-size:clamp(40px,5vw,64px);}
.sec-head h2 i{color:var(--brown);}
.sec-head p{font-size:18px;color:var(--muted);margin-top:14px;}

/* hero (home) */
.hero{padding:24px 0 0;}
.hero-panel{background:var(--mahogany);border-radius:36px;color:var(--cream);padding:60px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center;overflow:hidden;}
.hero-panel .eye{color:#f0d9c4;}
.hero h1{font-size:clamp(52px,6.4vw,96px);}
.hero h1 i{color:var(--copper-lt);}
.hero .sub{font-size:19px;line-height:1.6;opacity:.9;max-width:480px;margin:24px 0 32px;}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-figure{position:relative;border-radius:24px;overflow:hidden;height:460px;}
.hero-figure img{width:100%;height:100%;object-fit:cover;}
.hero-badge{position:absolute;left:20px;bottom:20px;background:var(--cream);color:var(--ink);
  border-radius:16px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px rgba(0,0,0,.2);}
.hero-badge .nv{font-family:"Instrument Serif",serif;font-size:20px;color:var(--copper);line-height:1;}
.hero-badge .nv b{display:block;font-family:"DM Sans";font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--orange-deep);margin-top:3px;}
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:34px;
  background:var(--cream);border-radius:22px;overflow:hidden;}
.stat{padding:24px 18px;text-align:center;border-right:1px solid rgba(91,58,35,.12);}
.stat:last-child{border-right:none;}
.stat b{font-family:"Instrument Serif",serif;font-size:34px;display:block;line-height:1;color:var(--copper);}
.stat span{font-size:12.5px;color:var(--muted);display:block;margin-top:7px;line-height:1.3;}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc{background:var(--cream);border-radius:26px;overflow:hidden;display:flex;flex-direction:column;
  transition:transform .15s,box-shadow .15s;}
.svc:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(91,58,35,.12);}
.svc .pic{height:170px;overflow:hidden;}
.svc .pic img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.svc:hover .pic img{transform:scale(1.05);}
.svc .body{padding:28px 30px 32px;}
.svc .kicker{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--copper);font-weight:700;}
.svc h3{font-family:"Instrument Serif",serif;font-size:29px;margin:8px 0 12px;}
.svc p{font-size:15px;color:var(--muted);line-height:1.6;}
.svc .more{display:inline-block;margin-top:16px;font-size:14px;font-weight:600;color:var(--orange-deep);}

/* process */
.process{background:var(--mahogany);color:var(--cream);}
.process .sec-head h2 i{color:var(--orange);}
.process .sec-head p{color:#e7d2bf;}
.process .eye{color:var(--orange);}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:30px 26px;}
.step .n{width:46px;height:46px;border-radius:50%;font-family:"Instrument Serif",serif;font-size:22px;
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--cream);}
.step:nth-child(odd) .n{background:var(--copper);}
.step:nth-child(even) .n{background:rgba(255,255,255,.16);}
.step h4{font-family:"Instrument Serif",serif;font-size:24px;margin-bottom:9px;}
.step h4 .tag{display:inline-block;font-family:"DM Sans";font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--ink);background:var(--copper);padding:3px 9px;border-radius:30px;margin-left:6px;vertical-align:middle;}
.step p{font-size:14.5px;color:#e7d2bf;line-height:1.55;}
.process .foot{text-align:center;margin-top:36px;font-family:"Space Mono",monospace;font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;color:#cbb39e;}

/* nivona band */
.nivona-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.nivona-figure{border-radius:30px;overflow:hidden;height:440px;}
.nivona-figure img{width:100%;height:100%;object-fit:cover;}
.nivona h2{font-size:clamp(38px,4.6vw,58px);}
.nivona h2 i{color:var(--orange);}
.nivona .lead{font-size:18px;color:var(--muted);line-height:1.6;margin:18px 0 26px;}
.nivona ul{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:28px;}
.nivona li{display:flex;gap:13px;font-size:15.5px;line-height:1.5;}
.nivona li .k{width:22px;height:22px;border-radius:50%;background:var(--copper);flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;margin-top:1px;}
.nivona .note{font-size:13px;color:var(--muted);line-height:1.55;margin-top:22px;padding-top:20px;border-top:1px solid rgba(91,58,35,.15);}

/* about */
.about{background:var(--cream);}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;}
.about-figure{border-radius:30px;overflow:hidden;height:420px;}
.about-figure img{width:100%;height:100%;object-fit:cover;}
.about h2{font-size:clamp(36px,4.4vw,54px);}
.about h2 i{color:var(--brown);}
.about p{font-size:17px;color:var(--muted);line-height:1.65;margin:18px 0;}
.brands-box{margin-top:26px;}
.brands-box .lab{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.brand-chips{display:flex;flex-wrap:wrap;gap:9px;}
.brand-chips span{font-size:14px;font-weight:600;background:#fff;border:1px solid rgba(91,58,35,.15);
  border-radius:30px;padding:8px 15px;color:var(--brown);}
.brand-chips span.star{background:var(--copper);color:var(--cream);border-color:var(--copper);}

/* testimonials */
.rev-head{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:44px;flex-wrap:wrap;text-align:center;}
.score{font-family:"Instrument Serif",serif;font-size:72px;line-height:.9;color:var(--copper);}
.rev-head .stars{color:var(--copper-lt);font-size:24px;letter-spacing:2px;}
.rev-head .lab{font-size:14px;color:var(--muted);}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.rev{background:var(--cream);border-radius:24px;padding:30px;}
.rev .stars{color:var(--copper-lt);font-size:15px;letter-spacing:2px;margin-bottom:14px;}
.rev p{font-size:15px;line-height:1.6;color:#3a2a1e;}
.rev .who{margin-top:18px;font-size:13.5px;font-weight:600;color:var(--muted);}

/* shop */
.shop{background:var(--mahogany);color:var(--cream);}
.shop .sec-head h2 i{color:var(--orange);}
.shop .sec-head p{color:#cbb39e;}
.shop .eye{color:var(--orange);}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.prod{background:#241a13;border:1px solid rgba(246,238,224,.1);border-radius:20px;padding:16px;transition:border-color .15s,transform .15s;}
.prod:hover{border-color:rgba(223,100,39,.5);transform:translateY(-3px);}
.prod .pimg{height:180px;border-radius:14px;margin-bottom:16px;overflow:hidden;}
.prod .pimg img{width:100%;height:100%;object-fit:cover;}
.prod .ptag{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#caa980;}
.prod h4{font-size:15.5px;font-weight:600;margin:7px 0 8px;line-height:1.3;}
.prod .price{font-family:"Instrument Serif",serif;font-size:24px;color:var(--copper-lt);}
.shop-cta{text-align:center;margin-top:40px;}

/* contact */
.contact{background:var(--mahogany);color:var(--cream);}
.contact .sec-head h2 i{color:var(--orange);}
.contact .sec-head p{color:#e7d2bf;}
.contact .eye{color:var(--orange);}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:start;}
.info-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:26px;padding:34px;}
.info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.12);}
.info-row:last-of-type{border-bottom:none;}
.info-row .ic{width:40px;height:40px;border-radius:12px;background:var(--copper);flex:none;display:flex;align-items:center;justify-content:center;font-size:18px;}
.info-row .t{font-size:12px;text-transform:uppercase;letter-spacing:.12em;opacity:.7;margin-bottom:4px;}
.info-row .v{font-size:15.5px;line-height:1.5;}
.info-row .v a:hover{color:#fff;text-decoration:underline;}
.map{height:200px;border-radius:18px;margin-top:22px;overflow:hidden;}
.map img{width:100%;height:100%;object-fit:cover;}

form.lead{background:var(--cream);border-radius:26px;padding:36px;color:var(--ink);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);
  background:#fff;border:1.5px solid rgba(91,58,35,.2);border-radius:12px;padding:12px 14px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);}
.field textarea{resize:vertical;min-height:110px;}
form.lead .btn{width:100%;justify-content:center;margin-top:6px;}
form.lead .hint{font-size:12.5px;color:var(--muted);text-align:center;margin-top:12px;}
.form-ok{background:#e7f3ea;border:1.5px solid #2f8a4e;color:#1c5e34;border-radius:14px;padding:16px 18px;font-size:14.5px;margin-top:14px;display:none;}
.form-ok.show{display:block;}

/* footer */
footer.site{background:var(--mahogany);color:#cbb39e;padding:64px 0 28px;}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(246,238,224,.12);}
.foot-top .blurb{font-size:14.5px;line-height:1.6;max-width:340px;margin-top:18px;}
.foot-col h5{color:var(--cream);font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;}
.foot-col a{display:block;font-size:14.5px;padding:5px 0;}
.foot-col a:hover{color:var(--copper-lt);}
.foot-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:13px;}
.foot-bar .legal{display:flex;gap:18px;flex-wrap:wrap;}

/* ===== SUBPAGES ===== */
/* page hero */
.page-hero{background:var(--mahogany);color:var(--cream);padding:56px 0 60px;}
.crumb{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#cbb39e;margin-bottom:20px;}
.crumb a:hover{color:var(--cream);}
.page-hero h1{font-size:clamp(40px,5.2vw,72px);max-width:880px;}
.page-hero h1 i{color:var(--orange);}
.page-hero .lead{font-size:19px;line-height:1.6;color:#ecd9c8;max-width:680px;margin-top:18px;}
.page-hero .kicker{display:inline-flex;align-items:center;gap:10px;font-size:12px;color:var(--orange);margin-bottom:16px;font-family:"Space Mono",monospace;letter-spacing:.14em;text-transform:uppercase;}
.page-hero .kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--copper);}

/* two-col content with figure */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.split.rev{grid-template-columns:.95fr 1.05fr;}
.split-figure{border-radius:28px;overflow:hidden;height:420px;}
.split-figure img{width:100%;height:100%;object-fit:cover;}
.split h2{font-size:clamp(32px,4vw,48px);margin-bottom:18px;}
.split h2 i{color:var(--brown);}
.split p{font-size:17px;color:var(--muted);line-height:1.65;margin-bottom:16px;}

/* checklist */
.checklist{list-style:none;display:flex;flex-direction:column;gap:13px;margin:8px 0 8px;}
.checklist li{display:flex;gap:13px;font-size:16px;line-height:1.5;}
.checklist li .k{width:22px;height:22px;border-radius:50%;background:var(--copper);flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;margin-top:2px;}

/* feature cards (defects, signs) */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.mini{background:var(--cream);border-radius:18px;padding:24px 26px;font-size:15.5px;line-height:1.5;color:#3a2a1e;display:flex;gap:13px;align-items:flex-start;}
.mini .b{width:9px;height:9px;border-radius:50%;background:var(--copper);flex:none;margin-top:7px;}

/* price cards */
.price-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:760px;margin:0 auto;}
.price-card{background:var(--cream);border-radius:22px;padding:32px;text-align:center;}
.price-card .pp{font-family:"Instrument Serif",serif;font-size:46px;color:var(--copper);line-height:1;}
.price-card h4{font-size:18px;font-weight:600;margin-top:10px;}
.price-note{text-align:center;font-size:13.5px;color:var(--muted);margin-top:22px;}

/* callout box */
.callout{background:#fbf4e7;border:1.5px solid var(--tan);border-radius:18px;padding:24px 28px;display:flex;gap:16px;align-items:flex-start;}
.callout .tag{font-family:"Space Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--copper);padding:5px 11px;border-radius:30px;flex:none;}
.callout p{font-size:15.5px;line-height:1.6;color:#3a2a1e;}

/* CTA band */
.cta-band{background:var(--copper);color:#fff;}
.cta-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.cta-band h2{font-family:"Instrument Serif",serif;font-size:clamp(30px,3.6vw,46px);line-height:1.05;}
.cta-band p{font-size:16px;opacity:.92;margin-top:8px;}
.cta-band .btn{background:var(--ink);}
.cta-band .btn:hover{background:#000;}

/* alt section bg */
.bg-cream{background:var(--cream);}

/* prose / legal + article */
.prose{font-size:16.5px;line-height:1.7;color:#3a2a1e;}
.prose h2{font-family:"Instrument Serif",serif;font-size:34px;color:var(--ink);margin:38px 0 14px;letter-spacing:-.01em;}
.prose h3{font-size:19px;font-weight:700;color:var(--ink);margin:26px 0 8px;}
.prose p{margin-bottom:14px;}
.prose ul{margin:0 0 16px 4px;list-style:none;display:flex;flex-direction:column;gap:9px;}
.prose ul li{position:relative;padding-left:22px;}
.prose ul li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--copper);}
.prose a{color:var(--copper);font-weight:600;text-decoration:underline;text-underline-offset:3px;}
.prose strong{color:var(--ink);}
.prose .meta{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.prose .updated{font-size:13.5px;color:var(--muted);margin-bottom:24px;}

/* FAQ accordion */
.faq-list{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--cream);border-radius:18px;overflow:hidden;border:1px solid rgba(91,58,35,.1);}
.faq-item summary{list-style:none;cursor:pointer;padding:24px 28px;display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-size:18px;font-weight:600;color:var(--ink);font-family:"Instrument Serif",serif;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary .plus{width:30px;height:30px;border-radius:50%;background:var(--bark,#3A2214);color:var(--cream);flex:none;
  display:flex;align-items:center;justify-content:center;font-size:20px;transition:transform .2s,background .2s;font-family:"DM Sans";}
.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--copper);}
.faq-item .ans{padding:0 28px 24px;font-size:15.5px;line-height:1.65;color:#3a2a1e;}

/* article cards (ratgeber index) */
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.art-card{background:var(--cream);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s;}
.art-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(91,58,35,.12);}
.art-card .pic{height:190px;overflow:hidden;}
.art-card .pic img{width:100%;height:100%;object-fit:cover;}
.art-card .body{padding:26px 28px 30px;display:flex;flex-direction:column;flex:1;}
.art-card .cat{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper);font-weight:700;}
.art-card h3{font-family:"Instrument Serif",serif;font-size:25px;margin:9px 0 10px;line-height:1.1;}
.art-card p{font-size:14.5px;color:var(--muted);line-height:1.55;flex:1;}
.art-card .read{margin-top:16px;font-size:13px;font-family:"Space Mono",monospace;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}

/* article hero figure */
.art-figure{border-radius:24px;overflow:hidden;height:360px;margin-bottom:36px;}
.art-figure img{width:100%;height:100%;object-fit:cover;}

@media(max-width:980px){
  .hero-panel,.nivona-grid,.about-grid,.contact-grid,.split,.split.rev{grid-template-columns:1fr;}
  .hero-figure,.nivona-figure,.about-figure,.split-figure{height:340px;}
  .svc-grid,.prod-grid,.art-grid{grid-template-columns:repeat(2,1fr);}
  .steps,.cards3{grid-template-columns:repeat(2,1fr);}
  .rev-grid{grid-template-columns:1fr 1fr;}
  .foot-top{grid-template-columns:1fr 1fr;}
  .links{display:none;}
}
@media(max-width:620px){
  .stats{grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(5){grid-column:span 2;border-right:none;}
  .svc-grid,.prod-grid,.steps,.rev-grid,.field-row,.foot-top,.cards3,.cards2,.art-grid,.price-cards{grid-template-columns:1fr;}
  section{padding:56px 0;}
  .hero-panel{padding:36px 28px;}
  .cta-band .wrap{flex-direction:column;align-items:flex-start;}
}

/* ═══════════════════════════════════════════
   MOBILE NAV + HAMBURGER
═══════════════════════════════════════════ */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  padding:.5rem;background:none;border:none;cursor:pointer;flex-shrink:0;}
.burger span{display:block;width:22px;height:1.5px;
  background:rgba(248,243,235,.75);
  border-radius:2px;transition:transform .24s,opacity .2s;}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

.mob-scrim{display:none;position:fixed;inset:0;background:rgba(42,29,20,.4);z-index:99;}
.mob-scrim.open{display:block;}

.mob-nav{position:fixed;top:0;right:0;bottom:0;width:min(300px,85vw);
  background:var(--bg);z-index:100;padding:72px 28px 36px;
  display:flex;flex-direction:column;gap:0;
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:-4px 0 32px rgba(42,29,20,.18);}
.mob-nav.open{transform:translateX(0);}
.mob-nav a{font-family:"Instrument Serif",serif;font-size:1.4rem;color:var(--ink);
  padding:.625rem 0;border-bottom:1px solid rgba(91,58,35,.1);display:block;
  transition:color .15s;}
.mob-nav a:hover{color:var(--orange-deep);}
.mob-cta{margin-top:1.25rem!important;background:var(--copper);color:#fff!important;
  text-align:center;border-radius:44px;padding:.875rem 1.5rem!important;
  font-family:"DM Sans",sans-serif!important;font-size:1rem!important;
  font-weight:700;border-bottom:none!important;}
.mob-cta:hover{background:var(--orange-deep)!important;}

@media(max-width:980px){
  .burger{display:flex;}
  .links{display:none;}
}

/* ═══════════════════════════════════════════
   RESPONSIVE IMPROVEMENTS
═══════════════════════════════════════════ */
@media(max-width:980px){
  .hero-panel{padding:40px 32px;}
  .hero h1{font-size:clamp(40px,7vw,72px);}
  .contact-grid{gap:24px;}
}
@media(max-width:620px){
  .hero-panel{padding:28px 20px;}
  .hero .cta{flex-direction:column;}
  .hero .cta a{width:100%;justify-content:center;}
  .page-hero{padding:40px 0 44px;}
  .page-hero h1{font-size:clamp(32px,8vw,52px);}
  .cta-band .wrap{padding:40px 20px;}
  form.lead{padding:24px 20px;}
  .field-row{grid-template-columns:1fr;}
  /* prevent iOS auto-zoom on form inputs */
  .field input,.field select,.field textarea{font-size:16px!important;}
}

/* ── Copper palette polish ─────────────────────────────── */
.sec-head h2 i{color:var(--copper);}
.about h2 i{color:var(--copper);}
.nivona h2 i{color:var(--copper-lt);}
.split h2 i{color:var(--copper);}
.kicker{color:var(--copper)!important;}
.eye{color:var(--copper)!important;}
a.svc:hover{box-shadow:0 16px 40px rgba(107,63,34,.15);}
.btn{background:var(--copper);}
.btn:hover{background:var(--orange-deep);}
.btn.ghost{background:transparent;color:var(--ivory);border:1.5px solid rgba(248,243,235,.32);}
.btn.ghost:hover{background:rgba(248,243,235,.1);}
.btn.line{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn.line:hover{background:var(--ink);color:var(--cream);}

/* ── Mobile Nav Button Fix ────────────────────────────────── */
@media(max-width:980px){
  .nav .cta { gap: 8px; }
  .nav .cta .btn {
    font-size: 13px;
    padding: .4rem .9rem;
    border-radius: 44px;
    min-width: unset;
    width: auto;
    display: flex;
    align-items: center;
    gap: 5px;
  }
  /* Hide the large round circle style on mobile */
  .nav .cta .btn { border-radius: 44px !important; }
}

/* ── Util bar mobile compact ──────────────────────────────── */
@media(max-width:620px){
  .util { font-size: 11.5px; padding: 6px 1rem; }
  .util-inner { flex-direction: column; gap: 3px; align-items: flex-start; }
  .util-addr { display: none; }
}

/* ── Nav CTA button: compact on all screens ───────────────── */
header.nav .btn {
  font-size: 14px;
  padding: 10px 18px;
  gap: 5px;
}
@media(max-width:620px){
  header.nav .btn {
    font-size: 13px;
    padding: 8px 14px;
  }
  /* Util bar: single line on mobile */
  .util-sep { display: none; }
}

/* ── Nav CTA: immer kompakt ──────────────────────────────────── */
header.nav .cta .btn {
  font-size: 13.5px !important;
  padding: 9px 16px !important;
  border-radius: 44px !important;
  line-height: 1.2 !important;
}

/* ── Callout: auf Mobile stacken ─────────────────────────── */
@media(max-width:620px){
  .callout {
    flex-direction: column;
    gap: 10px;
    padding: 18px 20px;
  }
  .callout .tag {
    align-self: flex-start;
  }
  .callout p {
    margin: 0;
  }
}
