/* Rosewood Studio — Workflow & Coordination Environment
   Palette: warm white, taupe, dusty rose, soft graphite, beige */

:root{
  --bg:#f3eee5;
  --paper:#faf6ee;
  --paper-2:#ebe3d3;
  --beige:#dccfb8;
  --cream:#f6f0e2;
  --taupe:#7a6a58;
  --taupe-2:#a08f7b;
  --rose:#c8a39c;
  --rose-2:#b58379;
  --silver:#d4cec5;
  --ink:#2b2520;
  --graphite:#48413a;
  --muted:#8a7d70;
  --line:rgba(43,37,32,.12);
  --line-soft:rgba(43,37,32,.06);
  --line-strong:rgba(43,37,32,.22);
  --shadow:0 30px 50px -28px rgba(43,37,32,.22);
  --shadow-card:0 14px 30px -16px rgba(43,37,32,.16);
  --r:6px;
  --r-md:12px;
  --r-lg:20px;
  --maxw:1320px;
  --gutter:clamp(20px,4vw,56px);
  --display:"Tenor Sans","Cormorant Garamond",Georgia,serif;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:15.5px;line-height:1.55;font-weight:400;
  letter-spacing:.003em;overflow-x:hidden;min-height:100vh;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}

/* subtle grid texture base */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(rgba(43,37,32,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(43,37,32,.018) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:.55;
}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(243,238,229,.85);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.nav{
  max-width:var(--maxw);margin:0 auto;padding:18px var(--gutter);
  display:flex;align-items:center;gap:32px;
}
.logo{display:flex;align-items:center;gap:14px;font-family:var(--display);font-weight:400;font-size:22px;letter-spacing:.01em;color:var(--ink);text-transform:none}
.logo-mark{
  width:40px;height:40px;border-radius:50%;flex:none;position:relative;
  background:var(--ink);
}
.logo-mark::before{
  content:"";position:absolute;inset:6px;border-radius:50%;
  background:var(--rose);
}
.logo-mark::after{
  content:"";position:absolute;left:50%;top:50%;width:14px;height:1px;
  background:var(--paper);transform:translate(-50%,-50%);
  box-shadow:0 -4px 0 var(--paper), 0 4px 0 var(--paper);
}
.logo small{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-top:2px;font-weight:500}
.logo .lg-wrap{display:flex;flex-direction:column;line-height:1.1}

.nav-links{display:flex;gap:4px;margin-left:auto;align-items:center;flex-wrap:wrap}
.nav-links a{
  font-size:13.5px;font-weight:500;padding:9px 14px;
  color:var(--graphite);transition:.2s;letter-spacing:.005em;
  position:relative;
}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:1px;background:var(--rose-2)}
.nav-cta{
  background:var(--ink)!important;color:var(--paper)!important;
  padding:11px 20px!important;border-radius:99px;font-weight:500!important;
}
.nav-cta:hover{background:var(--rose-2)!important;color:var(--paper)!important}

.menu-btn{display:none;width:42px;height:42px;border-radius:50%;background:var(--paper);align-items:center;justify-content:center;border:1px solid var(--line)}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.menu-btn span::before{top:-6px}.menu-btn span::after{top:6px}

@media (max-width:920px){
  .nav-links{
    position:fixed;inset:74px 0 0;background:var(--bg);
    flex-direction:column;align-items:stretch;padding:24px var(--gutter);gap:4px;
    transform:translateX(100%);transition:transform .35s;overflow:auto;z-index:60;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{padding:14px 16px;font-size:16px}
  .menu-btn{display:flex;margin-left:auto}
}

/* ============ HERO ============ */
.hero{
  max-width:var(--maxw);margin:0 auto;
  padding:80px var(--gutter) 100px;position:relative;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center}
@media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:60px}}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.22em;
  color:var(--rose-2);font-weight:500;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--rose-2)}

h1.title-xl{
  font-family:var(--display);font-weight:400;
  font-size:clamp(46px,7vw,96px);
  line-height:1.0;letter-spacing:-.015em;
  margin-top:24px;color:var(--ink);
}
.title-xl em{font-style:italic;color:var(--rose-2);font-weight:400;font-family:var(--serif)}
.title-xl .line{
  display:inline-block;position:relative;
}
.title-xl .line::after{
  content:"";position:absolute;left:0;right:0;bottom:-.04em;height:1px;background:var(--ink);opacity:.25;
}

.lede{margin-top:30px;font-size:17.5px;line-height:1.7;color:var(--graphite);max-width:54ch;font-weight:400}

.hero-actions{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:99px;
  font-weight:500;font-size:14px;letter-spacing:.01em;
  transition:.25s;border:1px solid transparent;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--rose-2);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--paper)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}

/* hero diagram — workflow nodes */
.hero-diagram{
  position:relative;aspect-ratio:1/1.05;max-width:540px;justify-self:end;width:100%;
}
@media (max-width:920px){.hero-diagram{justify-self:start;max-width:480px}}
.hero-diagram svg.flow{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;
}
.hero-diagram .node{
  position:absolute;background:var(--paper);border:1px solid var(--line-strong);
  padding:18px 22px;border-radius:var(--r);
  box-shadow:var(--shadow-card);
  min-width:170px;
}
.hero-diagram .node .h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--rose-2);text-transform:uppercase;font-weight:500;margin-bottom:8px}
.hero-diagram .node .t{font-family:var(--display);font-size:18px;line-height:1.2;color:var(--ink)}
.hero-diagram .node.accent{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.hero-diagram .node.accent .h{color:var(--rose)}
.hero-diagram .node.accent .t{color:var(--paper)}
.hero-diagram .node.rose{background:var(--rose);color:var(--ink);border-color:var(--rose)}
.hero-diagram .node.rose .h{color:var(--ink)}
.hero-diagram .n1{top:4%;left:4%}
.hero-diagram .n2{top:18%;right:0;background:var(--cream)}
.hero-diagram .n3{top:44%;left:14%}
.hero-diagram .n4{bottom:18%;right:6%}
.hero-diagram .n5{bottom:0;left:0}

.hero-strip{
  margin-top:80px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.hero-strip .cell{padding:32px 24px;border-right:1px solid var(--line-soft)}
.hero-strip .cell:last-child{border-right:0}
.hero-strip .num{font-family:var(--display);font-size:42px;line-height:1;color:var(--ink);font-weight:400}
.hero-strip .num small{font-size:18px;color:var(--rose-2);margin-left:6px;font-family:var(--serif);font-style:italic}
.hero-strip .lbl{margin-top:10px;font-size:12.5px;color:var(--muted);letter-spacing:.06em;line-height:1.5}
@media (max-width:760px){.hero-strip{grid-template-columns:repeat(2,1fr)}.hero-strip .cell:nth-child(2){border-right:0}.hero-strip .cell:nth-child(n+3){border-top:1px solid var(--line-soft)}}

/* ============ SECTIONS ============ */
.section{max-width:var(--maxw);margin:0 auto;padding:100px var(--gutter);position:relative}
.section--paper{background:var(--paper);max-width:none}
.section--paper > .inner{max-width:var(--maxw);margin:0 auto;padding:100px var(--gutter)}
.section--ink{background:var(--ink);color:#e3dcd0;max-width:none}
.section--ink > .inner{max-width:var(--maxw);margin:0 auto;padding:100px var(--gutter)}
.section--ink .section-head h2{color:#f5ede0}
.section--ink .section-head p{color:#aea69a}

.section-head{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:end;margin-bottom:64px}
@media (max-width:820px){.section-head{grid-template-columns:1fr;gap:20px}}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{font-family:var(--display);font-weight:400;font-size:clamp(34px,5vw,60px);line-height:1.05;letter-spacing:-.01em}
.section-head h2 em{font-style:italic;color:var(--rose-2);font-family:var(--serif)}
.section-head p{color:var(--graphite);font-size:16px;max-width:48ch;justify-self:end;line-height:1.65}
@media (max-width:820px){.section-head p{justify-self:start}}

/* ============ FLOW DIAGRAM BIG ============ */
.flow-board{
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:48px;
  position:relative;
  background-image:
    linear-gradient(rgba(43,37,32,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(43,37,32,.025) 1px, transparent 1px);
  background-size:32px 32px;
}
.flow-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
  position:relative;z-index:2;
}
@media (max-width:880px){.flow-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.flow-grid{grid-template-columns:1fr}}
.flow-step{
  background:var(--paper);border:1px solid var(--line-strong);
  border-radius:var(--r);padding:24px 22px;
  position:relative;transition:.3s;
  display:flex;flex-direction:column;gap:12px;min-height:200px;
}
.flow-step:hover{border-color:var(--ink);box-shadow:var(--shadow-card);transform:translateY(-3px)}
.flow-step .step-n{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--rose-2);text-transform:uppercase;font-weight:500}
.flow-step h3{font-family:var(--display);font-size:22px;font-weight:400;line-height:1.2}
.flow-step p{font-size:14px;color:var(--graphite);line-height:1.6}
.flow-step .meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}

/* connector line below grid */
.flow-connectors{
  position:absolute;left:0;right:0;top:50%;height:1px;
  background:repeating-linear-gradient(90deg,var(--line-strong) 0 8px,transparent 8px 16px);
  z-index:1;pointer-events:none;
}

/* ============ COORDINATION CARDS ============ */
.coord-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.coord{
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  transition:.3s;display:flex;flex-direction:column;
}
.coord:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--line-strong)}
.coord .ph{aspect-ratio:5/3;overflow:hidden;position:relative;background:var(--paper-2)}
.coord .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(8%) brightness(1.02);transition:transform .8s,filter .8s}
.coord:hover .ph img{transform:scale(1.04);filter:grayscale(0%)}
.coord .ph .layer{
  position:absolute;left:14px;top:14px;background:var(--paper);color:var(--ink);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  padding:6px 12px;border-radius:99px;border:1px solid var(--line);
}
.coord .body{padding:26px 28px 28px;flex:1;display:flex;flex-direction:column;gap:10px}
.coord h3{font-family:var(--display);font-weight:400;font-size:24px;line-height:1.15;letter-spacing:-.005em}
.coord p{font-size:14.5px;color:var(--graphite);line-height:1.6}
.coord .row-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center}
.coord .row-foot .lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.coord .row-foot .arr{color:var(--rose-2);transition:transform .25s}
.coord:hover .row-foot .arr{transform:translateX(6px)}
.coord.size-2{grid-column:span 6}
.coord.size-3{grid-column:span 4}
.coord.size-4{grid-column:span 3}
.coord.size-7{grid-column:span 7}
.coord.size-5{grid-column:span 5}
@media (max-width:980px){.coord.size-2,.coord.size-3,.coord.size-4,.coord.size-7,.coord.size-5{grid-column:span 6}}
@media (max-width:560px){.coord.size-2,.coord.size-3,.coord.size-4,.coord.size-7,.coord.size-5{grid-column:span 12}}

/* ============ COMMUNICATION MATRIX ============ */
.matrix{
  display:grid;grid-template-columns:200px repeat(4,1fr);
  border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  background:var(--paper);
}
.matrix > div{padding:18px 22px;border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.matrix > div:nth-child(5n){border-right:0}
.matrix .head{
  background:var(--ink);color:var(--paper);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
}
.matrix .row-lab{
  background:var(--paper-2);font-family:var(--display);font-size:17px;color:var(--ink);
}
.matrix .cell{font-size:13.5px;color:var(--graphite);line-height:1.55}
.matrix .cell .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.matrix .d-ok{background:#8a9d7f}
.matrix .d-async{background:#c8a39c}
.matrix .d-sync{background:#5b6f8a}
.matrix .d-meet{background:#b58379}
@media (max-width:780px){.matrix{grid-template-columns:1fr}.matrix > div{border-right:0!important}.matrix .head{display:none}.matrix .row-lab{background:var(--ink);color:var(--paper);font-size:14px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em}}

/* ============ SCHEDULE BOARD ============ */
.board{
  background:var(--ink);color:#e3dcd0;border-radius:var(--r-lg);
  padding:48px;display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  overflow:hidden;position:relative;
}
@media (max-width:880px){.board{grid-template-columns:repeat(2,1fr);gap:1px}}
@media (max-width:520px){.board{grid-template-columns:1fr}}
.board .col{padding:0 18px;border-right:1px solid rgba(227,220,208,.1)}
.board .col:last-child{border-right:0}
.board .day{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--rose);text-transform:uppercase;font-weight:500;margin-bottom:18px}
.board .slot{
  background:rgba(227,220,208,.06);border:1px solid rgba(227,220,208,.08);
  border-radius:var(--r);padding:14px;margin-bottom:10px;
  transition:.2s;
}
.board .slot:hover{background:rgba(227,220,208,.1);border-color:rgba(227,220,208,.18)}
.board .slot .time{font-family:var(--mono);font-size:11px;color:var(--rose);letter-spacing:.06em}
.board .slot .label{font-family:var(--display);font-size:15px;color:#f5ede0;margin-top:4px;line-height:1.25}
.board .slot.busy{background:rgba(184,131,121,.18);border-color:rgba(184,131,121,.35)}
.board .slot.busy .time{color:#e8c1b8}
.board .slot.busy .label{color:#f5ede0}

/* ============ SPLIT ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:36px}}
.split-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/6;position:relative;box-shadow:var(--shadow);background:var(--paper-2)}
.split-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(5%)}
.split-img .tag{position:absolute;left:20px;top:20px;background:var(--paper);color:var(--ink);padding:8px 14px;border-radius:99px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;border:1px solid var(--line)}
.split-text h3{font-family:var(--display);font-weight:400;font-size:clamp(28px,4vw,46px);line-height:1.1;letter-spacing:-.01em}
.split-text h3 em{font-style:italic;color:var(--rose-2);font-family:var(--serif)}
.split-text p{margin-top:18px;color:var(--graphite);font-size:16px;line-height:1.7}
.split-text .list{margin-top:24px;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.split-text .list li{display:grid;grid-template-columns:60px 1fr;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);font-size:15px;align-items:start}
.split-text .list .n{font-family:var(--mono);color:var(--rose-2);font-size:12px;letter-spacing:.1em;padding-top:4px}

/* ============ TIMELINE ============ */
.timeline{position:relative;padding-left:32px}
.timeline::before{
  content:"";position:absolute;left:6px;top:8px;bottom:8px;width:1px;
  background:var(--line-strong);
}
.tl-item{position:relative;padding-bottom:48px}
.tl-item::before{
  content:"";position:absolute;left:-32px;top:12px;width:13px;height:13px;
  background:var(--paper);border:1.5px solid var(--ink);border-radius:50%;
}
.tl-item .year{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--rose-2);font-weight:500}
.tl-item h4{font-family:var(--display);font-size:24px;font-weight:400;margin-top:8px;line-height:1.2}
.tl-item p{margin-top:12px;color:var(--graphite);font-size:15px;line-height:1.7;max-width:64ch}

/* ============ ROUTE DIAGRAM ============ */
.route-diagram{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
}
@media (max-width:820px){.route-diagram{grid-template-columns:1fr}}
.route-node{
  padding:32px;border-right:1px solid var(--line-soft);position:relative;
}
.route-node:last-child{border-right:0}
.route-node::after{
  content:"→";position:absolute;right:-12px;top:50%;transform:translateY(-50%);
  font-family:var(--mono);color:var(--rose-2);font-size:18px;
  background:var(--paper);padding:0 4px;z-index:2;
}
.route-node:last-child::after{display:none}
.route-node .n{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--rose-2);text-transform:uppercase}
.route-node h4{font-family:var(--display);font-size:22px;font-weight:400;line-height:1.2;margin-top:10px}
.route-node p{font-size:14px;color:var(--graphite);line-height:1.6;margin-top:10px}
@media (max-width:820px){.route-node::after{content:"↓";right:50%;top:auto;bottom:-14px;transform:translateX(50%)}.route-node{border-right:0;border-bottom:1px solid var(--line-soft)}.route-node:last-child{border-bottom:0}}

/* ============ INFO ROWS ============ */
.info-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.info-rows .row{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--line);align-items:start}
@media (max-width:680px){.info-rows .row{grid-template-columns:1fr;gap:8px}}
.info-rows .row .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--rose-2);padding-top:4px;font-weight:500}
.info-rows .row .v{font-size:16px;color:var(--ink);line-height:1.65}

/* ============ FEATURES ============ */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--paper)}
@media (max-width:900px){.features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.features{grid-template-columns:1fr}}
.feature{padding:32px 28px;border-right:1px solid var(--line-soft);transition:.25s;min-height:240px;display:flex;flex-direction:column}
.feature:last-child{border-right:0}
.feature:hover{background:var(--paper-2)}
.feature .ic{width:36px;height:36px;color:var(--rose-2);margin-bottom:18px}
.feature h4{font-family:var(--display);font-size:21px;font-weight:400;line-height:1.2}
.feature p{font-size:14px;color:var(--graphite);margin-top:10px;line-height:1.6}
.feature .badge{margin-top:auto;padding-top:14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
@media (max-width:900px){.feature{border-bottom:1px solid var(--line-soft)}.feature:nth-child(2n){border-right:0}.feature:nth-last-child(-n+2){border-bottom:0}}

/* ============ MARQUEE ============ */
.marquee{
  overflow:hidden;mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
  padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin:60px 0;background:var(--paper);
}
.marquee-track{
  display:flex;gap:48px;animation:scroll 38s linear infinite;
  font-family:var(--display);font-size:34px;font-weight:400;color:var(--taupe);
  white-space:nowrap;letter-spacing:-.01em;
}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track span::after{content:"·";font-size:42px;color:var(--rose-2)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ FAQ ============ */
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line);max-width:880px;margin:0 auto}
.faq{
  background:transparent;border-bottom:1px solid var(--line);
  overflow:hidden;transition:.2s;
}
.faq[open]{background:var(--paper)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:26px 0;display:grid;grid-template-columns:50px 1fr 40px;gap:18px;align-items:center;
  font-family:var(--display);font-size:21px;font-weight:400;line-height:1.25;letter-spacing:-.005em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .n{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--rose-2);text-transform:uppercase}
.faq .plus{
  width:36px;height:36px;border-radius:50%;background:var(--paper);
  border:1px solid var(--line-strong);display:grid;place-items:center;
  transition:.25s;color:var(--ink);
}
.faq[open] .plus{transform:rotate(45deg);background:var(--ink);color:var(--paper);border-color:var(--ink)}
.faq .ans{padding:0 0 28px 68px;color:var(--graphite);font-size:15.5px;line-height:1.75;max-width:74ch}
@media (max-width:560px){.faq summary{grid-template-columns:1fr 36px}.faq summary .n{display:none}.faq .ans{padding-left:0}}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:36px}}
.contact-info{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.contact-info .block{
  padding:24px 0;border-bottom:1px solid var(--line);
}
.contact-info .block .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--rose-2);text-transform:uppercase;font-weight:500}
.contact-info .block .val{margin-top:10px;font-family:var(--display);font-size:22px;font-weight:400;line-height:1.3}

.contact-form{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px;
  box-shadow:var(--shadow);
}
.contact-form h3{font-family:var(--display);font-size:30px;font-weight:400;line-height:1.1}
.contact-form p{margin-top:8px;color:var(--graphite);font-size:14.5px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
@media (max-width:540px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--rose-2);text-transform:uppercase;font-weight:500}
.field input,.field textarea,.field select{
  padding:14px 16px;border-radius:var(--r);border:1px solid var(--line-strong);
  background:#fff;transition:.2s;font-size:15px;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(184,131,121,.18)}
.field textarea{min-height:130px;resize:vertical;font-family:var(--sans)}
.form-full{grid-column:1/-1}
.form-actions{margin-top:28px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.form-actions .hint{font-size:12.5px;color:var(--muted);font-family:var(--mono);letter-spacing:.05em}

.map-wrap{
  border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/4;
  border:1px solid var(--line);box-shadow:var(--shadow);
  background:var(--paper-2);
}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(40%) sepia(.1) brightness(1.02)}

/* ============ FOOTER ============ */
footer.site-footer{
  background:var(--ink);color:#c0b6a5;padding:90px var(--gutter) 36px;margin-top:80px;
  position:relative;
}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:48px}
@media (max-width:900px){.footer-inner{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){.footer-inner{grid-template-columns:1fr}}
.footer-brand .logo{color:#f5ede0}
.footer-brand .logo small{color:#8c8275}
.footer-brand p{margin-top:18px;font-size:14px;line-height:1.65;color:#8c8275;max-width:38ch}
.footer-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:#8c8275;margin-bottom:18px;text-transform:uppercase;font-weight:500}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col li a{font-size:14.5px;color:#c0b6a5;transition:.2s}
.footer-col li a:hover{color:var(--rose)}
.footer-contact .row{font-size:14px;color:#c0b6a5;margin-bottom:10px;display:flex;gap:10px}
.footer-contact .row .ic{flex:none;color:var(--rose);margin-top:3px}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:rgba(245,237,224,.06);color:#c0b6a5;transition:.25s;
}
.socials a:hover{background:var(--rose);color:var(--ink);transform:translateY(-2px)}
.footer-bottom{
  max-width:var(--maxw);margin:48px auto 0;padding-top:24px;
  border-top:1px solid rgba(245,237,224,.08);
  display:flex;justify-content:space-between;font-size:12.5px;color:#6e6557;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);letter-spacing:.05em;
}

/* ============ COOKIE ============ */
.cookie{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:80;
  background:var(--ink);color:#c0b6a5;border-radius:var(--r-lg);padding:22px 24px;
  display:flex;gap:18px;align-items:center;justify-content:space-between;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.45);
  transform:translateY(140%);transition:transform .5s cubic-bezier(.5,1.4,.3,1);
  flex-wrap:wrap;max-width:760px;margin:0 auto;
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:13.5px;line-height:1.55;flex:1;min-width:260px}
.cookie a{color:var(--rose);text-decoration:underline}
.cookie button{padding:11px 20px;border-radius:99px;background:var(--rose);color:var(--ink);font-weight:500;font-size:13px}
.cookie button:hover{background:#d8b3aa}
.cookie .x{background:transparent;color:#8c8275;padding:8px 12px}

/* ============ B2T ============ */
.b2t{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:46px;height:46px;border-radius:50%;
  background:var(--ink);color:var(--paper);display:grid;place-items:center;
  box-shadow:0 16px 30px -12px rgba(43,37,32,.4);
  opacity:0;pointer-events:none;transform:translateY(20px);transition:.35s;
}
.b2t.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.b2t:hover{background:var(--rose-2)}

/* ============ ANIMS ============ */
.fx-up{will-change:transform}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}html{scroll-behavior:auto}}

/* ============ PAGE HERO ============ */
.page-hero{
  padding:80px var(--gutter) 50px;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:end;
}
@media (max-width:900px){.page-hero{grid-template-columns:1fr}}
.page-hero .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--rose-2);display:flex;gap:10px;align-items:center;text-transform:uppercase;font-weight:500}
.page-hero h1{font-family:var(--display);font-weight:400;font-size:clamp(40px,6vw,76px);line-height:1.0;letter-spacing:-.015em;margin-top:24px}
.page-hero h1 em{font-style:italic;color:var(--rose-2);font-family:var(--serif)}
.page-hero .intro{font-size:17px;color:var(--graphite);line-height:1.7}

/* ============ ASIDE LAYOUT ============ */
.aside-layout{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}
@media (max-width:900px){.aside-layout{grid-template-columns:1fr}}
.aside-layout aside{position:sticky;top:100px}
.aside-layout aside h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--rose-2);margin-bottom:14px;text-transform:uppercase;font-weight:500}
.aside-layout aside ul{display:flex;flex-direction:column;border-left:1px solid var(--line)}
.aside-layout aside ul li{padding:12px 16px;font-size:14.5px;color:var(--graphite);cursor:pointer;transition:.2s;border-left:1px solid transparent;margin-left:-1px;font-weight:500}
.aside-layout aside ul li:hover{color:var(--ink);border-left-color:var(--rose-2)}
.aside-layout aside ul li.active{color:var(--ink);border-left-color:var(--ink);background:var(--paper);font-weight:500}

/* ============ ARCHIVE ============ */
.archive{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.archive .item{
  display:grid;grid-template-columns:90px 1fr auto 70px;gap:24px;align-items:center;
  padding:24px 8px;border-bottom:1px solid var(--line);
  transition:.2s;cursor:pointer;
}
.archive .item:hover{background:var(--paper);padding-left:24px}
.archive .item .yr{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;color:var(--rose-2)}
.archive .item h4{font-family:var(--display);font-size:21px;font-weight:400;line-height:1.2}
.archive .item .cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe);padding:5px 11px;border-radius:99px;background:var(--paper);border:1px solid var(--line)}
.archive .item .arr{color:var(--rose-2);transition:transform .2s}
.archive .item:hover .arr{transform:translateX(6px)}
@media (max-width:680px){.archive .item{grid-template-columns:90px 1fr;gap:14px}.archive .item .cat,.archive .item .arr{display:none}}

/* ============ PULL ============ */
.pull{max-width:980px;margin:0 auto;text-align:center;position:relative}
.pull blockquote{
  font-family:var(--display);font-weight:400;
  font-size:clamp(26px,3.5vw,42px);line-height:1.25;letter-spacing:-.005em;color:var(--ink);
}
.pull blockquote em{font-family:var(--serif);font-style:italic;color:var(--rose-2)}
.pull cite{display:block;margin-top:28px;font-style:normal;font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--rose-2);text-transform:uppercase;font-weight:500}

.center{text-align:center}
.muted{color:var(--muted)}

/* divider */
.divider-line{
  display:flex;align-items:center;gap:18px;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;
}
.divider-line::before,.divider-line::after{content:"";flex:1;height:1px;background:var(--line-strong)}
