@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* ===== Furniture Story — Kontakt & Showroom =====
   Ported 1:1 from mockup +Makieta/contact.html (content sections only; OpenCart
   header/footer chrome is kept). Everything scoped under .fs-contact so it does
   not collide with OpenCart's Bootstrap theme. :root tokens stay global and match
   furniture_story_about.css / furniture_story_pdp.css. */

:root{
  --bg:#FAF8F4;
  --bg-alt:#F2EDE5;
  --bg-warm:#E8DFD2;
  --bg-deep:#1F1B17;
  --ink:#1A1A1A;
  --ink-soft:#4A4744;
  --muted:#8B857E;
  --line:#E5DFD5;
  --line-strong:#D7CFC2;
  --accent:#5C5347;
  --sage:#8A9A7B;
  --terracotta:#B66B4A;
  --white:#FFFFFF;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition:0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.fs-contact{
  font-family:var(--sans);font-size:16px;line-height:1.7;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
.fs-contact *{margin:0;padding:0;box-sizing:border-box;}
.fs-contact img{max-width:100%;display:block;}
.fs-contact a{color:inherit;text-decoration:none;transition:opacity var(--transition);}
.fs-contact a:hover{opacity:0.7;}
.fs-contact button{font-family:inherit;cursor:pointer;border:none;background:none;}

/* ===== HERO — editorial intro ===== */
.fs-contact .hero{
  position:relative;
  padding:96px 48px 80px;
  background:var(--bg);
  text-align:center;
  border-bottom:1px solid var(--line);
}
.fs-contact .chapter-tag{
  font-family:var(--sans);font-size:11px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--terracotta);font-weight:500;
  display:inline-flex;align-items:center;gap:14px;
  margin-bottom:28px;
}
.fs-contact .chapter-tag::before, .fs-contact .chapter-tag::after{
  content:"";flex:0 0 36px;height:1px;background:var(--line-strong);
}
.fs-contact .hero h1{
  font-family:var(--serif);
  font-size:clamp(48px, 6vw, 92px);
  line-height:1.05;font-weight:500;letter-spacing:-0.015em;
  margin-bottom:24px;max-width:18ch;margin-inline:auto;
}
.fs-contact .hero h1 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .hero p{
  font-family:var(--serif);font-style:italic;
  font-size:22px;line-height:1.5;color:var(--ink-soft);
  max-width:680px;margin:0 auto;
}

/* ===== Quick channels strip ===== */
.fs-contact .channels{
  background:var(--bg);
  padding:40px 48px;
  border-bottom:1px solid var(--line);
}
.fs-contact .channels-inner{
  width:100%;margin:0;
  display:grid;grid-template-columns:repeat(4, 1fr);gap:0;
  border:1px solid var(--line);
  border-radius:2px;
  overflow:hidden;
}
.fs-contact .channel{
  display:flex;align-items:center;gap:18px;
  padding:24px 28px;
  border-right:1px solid var(--line);
  transition:background var(--transition);
  cursor:pointer;
}
.fs-contact .channel:last-child{border-right:none;}
.fs-contact .channel:hover{background:var(--bg-alt);opacity:1;}
.fs-contact .channel-icon{
  width:44px;height:44px;flex-shrink:0;
  border-radius:50%;background:var(--bg-warm);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
}
.fs-contact .channel-icon svg{width:18px;height:18px;}
.fs-contact .channel-text .l{
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:3px;
}
.fs-contact .channel-text .v{
  font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);
  line-height:1.2;word-break:break-word;
}
.fs-contact .channel-text .v em{font-style:italic;color:var(--terracotta);font-weight:400;}

/* ===== Showroom + form layout ===== */
.fs-contact .main-section{
  padding:96px 48px;
  background:var(--bg);
}
.fs-contact .main-grid{
  width:100%;margin:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
/* LEFT: showroom card */
.fs-contact .showroom-card{position:relative;}
.fs-contact .showroom-img{
  aspect-ratio:5/4;
  background:var(--bg-warm);
  overflow:hidden;
  border-radius:2px;
  margin-bottom:32px;
}
.fs-contact .showroom-img img{width:100%;height:100%;object-fit:cover;}
.fs-contact .showroom-card .lbl{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--terracotta);font-weight:600;
  margin-bottom:10px;
}
.fs-contact .showroom-card h2{
  font-family:var(--serif);
  font-size:clamp(34px, 3.4vw, 48px);
  line-height:1.15;font-weight:500;letter-spacing:-0.01em;
  margin-bottom:18px;
}
.fs-contact .showroom-card h2 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .showroom-card p{
  font-size:16px;line-height:1.8;color:var(--ink-soft);
  margin-bottom:18px;
}
.fs-contact .showroom-meta{
  margin-top:32px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px 36px;
  padding-top:28px;border-top:1px solid var(--line-strong);
}
.fs-contact .meta-cell{display:flex;gap:14px;align-items:flex-start;}
.fs-contact .meta-icon{
  width:36px;height:36px;flex-shrink:0;
  border:1px solid var(--line-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
}
.fs-contact .meta-icon svg{width:14px;height:14px;}
.fs-contact .meta-cell strong{
  display:block;font-family:var(--sans);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:6px;
}
.fs-contact .meta-cell .meta-body{font-size:14px;line-height:1.7;color:var(--ink-soft);}
.fs-contact .showroom-actions{
  margin-top:32px;
  display:flex;gap:12px;flex-wrap:wrap;
}
.fs-contact .btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;
  font-family:var(--sans);font-size:12px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  border-radius:2px;
  transition:background var(--transition), color var(--transition), border-color var(--transition);
}
.fs-contact .btn-primary{background:var(--ink);color:var(--bg);}
.fs-contact .btn-primary:hover{background:var(--accent);opacity:1;color:var(--bg);}
.fs-contact .btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink);}
.fs-contact .btn-outline:hover{background:var(--ink);color:var(--bg);opacity:1;}
.fs-contact .btn svg{width:14px;height:14px;}

/* RIGHT: form card */
.fs-contact .form-card{
  background:var(--bg-alt);
  padding:48px;
  border-radius:2px;
  position:sticky;top:24px;
}
.fs-contact .form-card .lbl{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--terracotta);font-weight:600;
  margin-bottom:10px;
}
.fs-contact .form-card h2{
  font-family:var(--serif);
  font-size:clamp(30px, 3vw, 42px);
  line-height:1.15;font-weight:500;letter-spacing:-0.01em;
  margin-bottom:14px;
}
.fs-contact .form-card h2 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .form-card .deck{
  font-family:var(--serif);font-style:italic;
  font-size:17px;color:var(--ink-soft);margin-bottom:28px;
  line-height:1.5;
}

.fs-contact .topic-row{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;}
.fs-contact .topic{
  padding:8px 14px;
  font-size:11px;letter-spacing:0.06em;
  background:var(--bg);
  border:1px solid var(--line-strong);
  border-radius:999px;
  color:var(--ink-soft);
  cursor:pointer;
  transition:all var(--transition);
}
.fs-contact .topic:hover{border-color:var(--ink);}
.fs-contact .topic.active{background:var(--ink);color:var(--bg);border-color:var(--ink);}

.fs-contact .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.fs-contact .field-row.full{grid-template-columns:1fr;}
.fs-contact .field label{
  display:block;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:8px;
}
.fs-contact .field label .opt{text-transform:none;letter-spacing:0;color:var(--muted);}
.fs-contact .field input,
.fs-contact .field select,
.fs-contact .field textarea,
.fs-contact input[type="text"],
.fs-contact input[type="email"],
.fs-contact input[type="tel"],
.fs-contact textarea{
  width:100%;
  padding:14px 16px;
  font-family:var(--sans);font-size:14px;color:var(--ink);
  background:var(--bg);
  border:1px solid var(--line-strong);
  border-radius:2px;
  transition:border-color var(--transition);
}
.fs-contact .field textarea,
.fs-contact textarea{min-height:120px;resize:vertical;}
.fs-contact .field input:focus,
.fs-contact .field select:focus,
.fs-contact .field textarea:focus,
.fs-contact input:focus,
.fs-contact textarea:focus{
  outline:none;border-color:var(--ink);
}
.fs-contact .check-row{
  display:flex;align-items:flex-start;gap:12px;
  font-size:13px;color:var(--ink-soft);margin:18px 0 24px;
}
.fs-contact .check-row input{margin-top:3px;accent-color:var(--ink);width:auto;}
.fs-contact .form-card button[type="submit"]{
  width:100%;padding:18px 24px;
  background:var(--ink);color:var(--bg);
  font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  border-radius:2px;
  transition:background var(--transition);
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.fs-contact .form-card button[type="submit"]:hover{background:var(--accent);}
.fs-contact .form-card button[type="submit"] svg{width:14px;height:14px;flex-shrink:0;}
.fs-contact .form-foot{
  margin-top:18px;font-size:12px;color:var(--muted);text-align:center;
}
.fs-contact .form-foot a{text-decoration:underline;}
.fs-contact .text-danger{color:#B3261E;font-size:12px;margin-top:6px;}

/* OpenCart captcha block sits inside the card */
.fs-contact .form-card .buttons{margin:0;}
.fs-contact .form-card .form-group{margin-bottom:14px;}

/* ===== Map / large showroom strip ===== */
.fs-contact .findus{
  background:var(--bg-alt);
  padding:96px 48px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.fs-contact .findus-grid{
  width:100%;margin:0;
  display:grid;grid-template-columns:1fr 1.4fr;gap:48px;
  align-items:stretch;
}
.fs-contact .findus-text .lbl{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--terracotta);font-weight:600;
  margin-bottom:10px;
}
.fs-contact .findus-text h3{
  font-family:var(--serif);
  font-size:clamp(32px, 3vw, 44px);
  line-height:1.15;font-weight:500;letter-spacing:-0.01em;
  margin-bottom:18px;
}
.fs-contact .findus-text h3 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .findus-text p{
  font-size:15px;line-height:1.8;color:var(--ink-soft);margin-bottom:14px;
}
.fs-contact .findus-list{
  margin-top:28px;
  display:flex;flex-direction:column;gap:14px;
}
.fs-contact .findus-list li{
  list-style:none;
  display:grid;grid-template-columns:auto 1fr;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--line-strong);
  align-items:flex-start;
  font-size:14px;line-height:1.7;color:var(--ink-soft);
}
.fs-contact .findus-list li:last-child{border-bottom:none;}
.fs-contact .findus-list .li-icon{
  width:32px;height:32px;
  border:1px solid var(--line-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);background:var(--bg);
}
.fs-contact .findus-list .li-icon svg{width:13px;height:13px;}
.fs-contact .findus-list strong{
  display:block;font-family:var(--sans);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:4px;
}

/* MAP — stylised, no external API */
.fs-contact .map{
  position:relative;
  background:var(--bg-warm);
  border-radius:2px;overflow:hidden;
  min-height:480px;
  background-image:
    linear-gradient(180deg, rgba(232, 223, 210, 0.92), rgba(232, 223, 210, 0.92)),
    repeating-linear-gradient(45deg, rgba(184, 165, 138, 0.18) 0, rgba(184, 165, 138, 0.18) 1px, transparent 1px, transparent 14px),
    repeating-linear-gradient(-45deg, rgba(184, 165, 138, 0.14) 0, rgba(184, 165, 138, 0.14) 1px, transparent 1px, transparent 28px);
}
.fs-contact .map-streets{position:absolute;inset:0;}
.fs-contact .map-streets .road{
  position:absolute;background:rgba(255,255,255,0.7);
  box-shadow:0 0 0 1px rgba(184, 165, 138, 0.3);
}
.fs-contact .map-streets .road.h{height:8px;left:0;right:0;}
.fs-contact .map-streets .road.v{width:8px;top:0;bottom:0;}
.fs-contact .map-streets .road.thick{height:14px;background:rgba(255,255,255,0.85);}
.fs-contact .map-streets .road.thick.v{width:14px;}
.fs-contact .map-river{
  position:absolute;
  background:rgba(138, 154, 123, 0.22);
  border:1px solid rgba(138, 154, 123, 0.4);
}
.fs-contact .map-label{
  position:absolute;
  font-family:var(--sans);font-size:10px;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(74, 71, 68, 0.6);
  font-weight:500;
}
.fs-contact .map-pin{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%, -100%);
  z-index:5;
}
.fs-contact .map-pin-icon{
  width:48px;height:48px;
  background:var(--terracotta);color:var(--bg);
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(182, 107, 74, 0.45);
  position:relative;
}
.fs-contact .map-pin-icon::after{
  content:"";position:absolute;
  top:50%;left:50%;transform:translate(-50%, -50%) rotate(45deg);
  width:14px;height:14px;background:var(--bg);border-radius:50%;
}
.fs-contact .map-pin-label{
  position:absolute;top:60px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:var(--bg);
  padding:8px 14px;border-radius:2px;
  font-size:11px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;
  white-space:nowrap;
  box-shadow:0 4px 16px rgba(26,26,26,0.2);
}
.fs-contact .map-pin-label::before{
  content:"";position:absolute;
  top:-5px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:8px;height:8px;background:var(--ink);
}
.fs-contact .map-overlay-actions{
  position:absolute;bottom:24px;right:24px;
  display:flex;gap:10px;
  z-index:6;
}
.fs-contact .map-overlay-actions a{
  background:var(--bg);
  padding:10px 16px;
  font-size:11px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;
  border-radius:2px;
  box-shadow:0 4px 16px rgba(26,26,26,0.1);
  display:inline-flex;align-items:center;gap:8px;
}
.fs-contact .map-overlay-actions a:hover{background:var(--ink);color:var(--bg);}
.fs-contact .map-overlay-actions svg{width:13px;height:13px;}

/* ===== Trade / press strip ===== */
.fs-contact .trade{
  padding:96px 48px;
  background:var(--bg);
}
.fs-contact .trade-grid{
  width:100%;margin:0;
  display:grid;grid-template-columns:repeat(3, 1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:2px;
}
.fs-contact .trade-card{
  background:var(--bg);
  padding:48px 36px;
}
.fs-contact .trade-card .num{
  font-family:var(--serif);font-style:italic;
  font-size:18px;color:var(--terracotta);
  margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.fs-contact .trade-card .num::before{
  content:"";width:24px;height:1px;background:var(--terracotta);
}
.fs-contact .trade-card h4{
  font-family:var(--serif);
  font-size:26px;font-weight:500;line-height:1.2;
  margin-bottom:14px;
}
.fs-contact .trade-card h4 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .trade-card p{font-size:14px;line-height:1.7;color:var(--ink-soft);margin-bottom:18px;}
.fs-contact .trade-card a.link{
  font-size:12px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--ink);
  padding-bottom:3px;
}
.fs-contact .trade-card a.link svg{width:13px;height:13px;}

/* ===== FAQ ===== */
.fs-contact .faq{
  padding:96px 48px;
  background:var(--bg-alt);
}
.fs-contact .faq-inner{max-width:880px;margin:0 auto;}
.fs-contact .faq-head{text-align:center;margin-bottom:48px;}
.fs-contact .faq-head .lbl{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--terracotta);font-weight:600;
  margin-bottom:14px;
}
.fs-contact .faq-head h3{
  font-family:var(--serif);
  font-size:clamp(34px, 4vw, 48px);
  line-height:1.15;font-weight:500;letter-spacing:-0.01em;
}
.fs-contact .faq-head h3 em{font-style:italic;color:var(--terracotta);font-weight:400;}
.fs-contact .faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-strong);}
.fs-contact details.faq-item{border-bottom:1px solid var(--line-strong);}
.fs-contact details.faq-item summary{
  list-style:none;
  padding:24px 0;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  cursor:pointer;
  font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.3;
  color:var(--ink);
}
.fs-contact details.faq-item summary::-webkit-details-marker{display:none;}
.fs-contact details.faq-item summary::after{
  content:"+";font-size:24px;color:var(--terracotta);font-family:var(--sans);
  transition:transform var(--transition);
  flex-shrink:0;
}
.fs-contact details.faq-item[open] summary::after{content:"\2212";}
.fs-contact details.faq-item .faq-body{
  padding:0 0 28px;font-size:15px;line-height:1.8;color:var(--ink-soft);
}
.fs-contact details.faq-item .faq-body a{text-decoration:underline;text-underline-offset:3px;}

/* ===== Responsive ===== */
@media(max-width:1024px){
  .fs-contact .channels-inner{grid-template-columns:repeat(2, 1fr);}
  .fs-contact .channel:nth-child(2){border-right:none;}
  .fs-contact .channel{border-bottom:1px solid var(--line);}
  .fs-contact .channel:nth-last-child(-n+2){border-bottom:none;}
  .fs-contact .main-grid{grid-template-columns:1fr;gap:48px;}
  .fs-contact .form-card{position:static;}
  .fs-contact .findus-grid{grid-template-columns:1fr;gap:32px;}
  .fs-contact .map{min-height:380px;}
  .fs-contact .trade-grid{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .fs-contact .hero{padding:64px 24px 56px;}
  .fs-contact .channels{padding:24px 20px;}
  .fs-contact .channels-inner{grid-template-columns:1fr;}
  .fs-contact .channel{border-right:none;border-bottom:1px solid var(--line);}
  .fs-contact .channel:last-child{border-bottom:none;}
  .fs-contact .main-section,
  .fs-contact .findus,
  .fs-contact .trade,
  .fs-contact .faq{padding-left:24px;padding-right:24px;padding-top:64px;padding-bottom:64px;}
  .fs-contact .form-card{padding:32px 24px;}
  .fs-contact .field-row{grid-template-columns:1fr;}
  .fs-contact .showroom-meta{grid-template-columns:1fr;}
}
