/* =========================================================
   Diplomacy . A Bar of Quiet Negotiations
   Palette
     --ink     #0e1218  midnight, the back of the bar
     --ink-2   #161b24  velvet booth
     --ink-3   #1f2632  marble shadow
     --paper   #f4ead7  treaty parchment
     --bone    #d8cdb4  unfolded napkin
     --brass   #c89b5a  chandelier brass
     --brass-2 #a87a3c  signet stamp
     --oxblood #5a1a22  embassy seat
     --jade    #2d4a3e  reading booth wallpaper
   Type
     Cinzel              titles, seals (Trajan/inscription substitute)
     Cormorant Garamond  body display, treaty (Garamond family)
     Inter               UI, meta, forms
   ========================================================= */

:root {
    --ink: #0e1218;
    --ink-2: #161b24;
    --ink-3: #1f2632;
    --paper: #f4ead7;
    --bone: #d8cdb4;
    --brass: #c89b5a;
    --brass-2: #a87a3c;
    --oxblood: #5a1a22;
    --jade: #2d4a3e;

    --font-display: "Cinzel", "Cormorant Garamond", "Times New Roman", serif;
    --font-serif: "Cormorant Garamond", "Times New Roman", Georgia, serif;
    --font-sans: "Inter", system-ui, -apple-system, "Helvetica Neue", sans-serif;

    --maxw: 1240px;
    --gutter: clamp(20px, 4vw, 56px);
}

* {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    background: var(--ink);
    color: var(--paper);
    font-family: var(--font-sans);
    font-weight: 300;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    scroll-behavior: smooth;
}

body {
    overflow-x: hidden;
    background:
        radial-gradient(ellipse 80% 50% at 50% 0%, rgba(200, 155, 90, 0.10), transparent 70%),
        radial-gradient(ellipse 60% 40% at 100% 80%, rgba(90, 26, 34, 0.18), transparent 70%),
        var(--ink);
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: transparent; border: 0; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

/* film grain overlay */
.grain-overlay {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 100;
    opacity: 0.06;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.92  0 0 0 0 0.84  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    padding: 16px 0;
    transition: background 380ms ease, backdrop-filter 380ms ease, padding 380ms ease, border-color 380ms ease;
    border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
    background: rgba(14, 18, 24, 0.82);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    padding: 10px 0;
    border-bottom: 1px solid rgba(200, 155, 90, 0.18);
}

.header-inner {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--gutter);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 32px;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: var(--brass);
}
.brand-mark { display: inline-flex; }
.brand-mark svg { transition: transform 600ms ease; }
.brand:hover .brand-mark svg { transform: rotate(40deg); }
.brand-words { display: flex; flex-direction: column; line-height: 1; }
.brand-name {
    font-family: var(--font-display);
    font-weight: 500;
    letter-spacing: 0.22em;
    font-size: 18px;
    color: var(--paper);
    text-transform: uppercase;
}
.brand-sub {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 12px;
    margin-top: 4px;
    color: var(--brass);
    letter-spacing: 0.04em;
}

.primary-nav {
    display: flex;
    justify-content: center;
    gap: clamp(18px, 2.4vw, 36px);
}
.primary-nav a {
    font-size: 12px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--bone);
    position: relative;
    padding: 6px 2px;
    transition: color 220ms ease;
}
.primary-nav a::after {
    content: "";
    position: absolute;
    left: 0; right: 0;
    bottom: 0;
    height: 1px;
    background: var(--brass);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 320ms ease;
}
.primary-nav a:hover { color: var(--paper); }
.primary-nav a:hover::after { transform: scaleX(1); }

.btn-reserve {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 11px 18px;
    border: 1px solid var(--brass);
    color: var(--paper);
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    background: transparent;
    transition: background 280ms ease, color 280ms ease, transform 280ms ease;
    position: relative;
    overflow: hidden;
}
.btn-reserve::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--brass);
    transform: translateX(-101%);
    transition: transform 360ms ease;
    z-index: -1;
}
.btn-reserve:hover { color: var(--ink); }
.btn-reserve:hover::before { transform: translateX(0); }
.btn-arrow { transition: transform 320ms ease; }
.btn-reserve:hover .btn-arrow { transform: translateX(4px); }

/* =========================================================
   HERO
   ========================================================= */
.hero {
    position: relative;
    min-height: 100vh;
    padding: 120px var(--gutter) 80px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}
.globe-art {
    position: absolute;
    right: -10%;
    top: 50%;
    transform: translateY(-50%);
    width: 95vh;
    height: 95vh;
    max-width: 900px;
    max-height: 900px;
    opacity: 0.65;
    filter: drop-shadow(0 0 40px rgba(200, 155, 90, 0.15));
    animation: globeRotate 90s linear infinite;
}
@keyframes globeRotate {
    from { transform: translateY(-50%) rotate(0deg); }
    to   { transform: translateY(-50%) rotate(360deg); }
}
.globe-lines circle, .globe-lines ellipse, .globe-lines line {
    transition: stroke-opacity 600ms ease;
}

.capital-coords {
    position: absolute;
    right: var(--gutter);
    bottom: 60px;
    color: var(--brass);
    font-family: var(--font-sans);
    text-align: right;
    line-height: 1.2;
    z-index: 2;
}
.coord-label {
    display: block;
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--bone);
    opacity: 0.7;
    margin-bottom: 8px;
}
.coord-city {
    display: block;
    font-family: var(--font-display);
    font-size: 20px;
    letter-spacing: 0.2em;
    color: var(--paper);
    margin-bottom: 6px;
    transition: opacity 380ms ease;
}
.coord-degrees {
    display: block;
    font-size: 11px;
    letter-spacing: 0.16em;
    color: var(--brass);
    transition: opacity 380ms ease;
}
.is-fading { opacity: 0; }

.hero-content {
    position: relative;
    z-index: 1;
    max-width: 760px;
    margin: 0 auto 0 0;
}

.hero-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 36px;
    color: var(--brass);
}
.eyebrow-line {
    flex: 0 0 60px;
    height: 1px;
    background: var(--brass);
}
.eyebrow-text {
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
}

.hero-title {
    font-family: var(--font-serif);
    font-weight: 400;
    font-size: clamp(46px, 8vw, 108px);
    line-height: 1.02;
    letter-spacing: -0.01em;
    margin: 0 0 32px;
    color: var(--paper);
}
.title-line {
    display: block;
    overflow: hidden;
}
.title-line.italic {
    font-style: italic;
    color: var(--brass);
    font-weight: 300;
}

.hero-lede {
    font-family: var(--font-serif);
    font-size: clamp(17px, 1.3vw, 20px);
    line-height: 1.55;
    color: var(--bone);
    max-width: 540px;
    margin: 0 0 40px;
}

.hero-actions {
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 64px;
}

.btn-primary {
    --bg: var(--brass);
    --fg: var(--ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 16px 28px;
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    font-weight: 500;
    position: relative;
    transition: background 280ms ease, color 280ms ease, transform 280ms ease, box-shadow 280ms ease;
    border: 1px solid var(--bg);
    box-shadow: 0 0 0 0 rgba(200, 155, 90, 0.0);
}
.btn-primary:hover {
    background: var(--paper);
    border-color: var(--paper);
    box-shadow: 0 8px 28px rgba(200, 155, 90, 0.22);
    transform: translateY(-1px);
}
.btn-primary.btn-large { padding: 20px 36px; font-size: 13px; }
.btn-primary.btn-small { padding: 14px 22px; font-size: 11px; }

.btn-stamp { position: relative; }

.btn-ghost {
    display: inline-flex;
    align-items: center;
    padding: 16px 28px;
    color: var(--paper);
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    border: 1px solid rgba(216, 205, 180, 0.4);
    transition: border-color 240ms ease, color 240ms ease, background 240ms ease;
}
.btn-ghost:hover {
    border-color: var(--brass);
    color: var(--brass);
    background: rgba(200, 155, 90, 0.06);
}

.hero-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    max-width: 620px;
    border-top: 1px solid rgba(216, 205, 180, 0.18);
    padding-top: 24px;
}
.meta-item { display: flex; flex-direction: column; gap: 6px; }
.meta-key {
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--brass);
}
.meta-val {
    font-family: var(--font-serif);
    font-size: 16px;
    color: var(--bone);
}

.hero-scroll {
    position: absolute;
    left: var(--gutter);
    bottom: 36px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    color: var(--bone);
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    opacity: 0.7;
}
.scroll-line {
    width: 1px;
    height: 50px;
    background: linear-gradient(to bottom, var(--brass), transparent);
    animation: scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse {
    0%, 100% { transform: scaleY(0.5); transform-origin: top; opacity: 0.4; }
    50%      { transform: scaleY(1); opacity: 1; }
}

/* =========================================================
   SECTION FRAMES
   ========================================================= */
.section-frame {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 100px var(--gutter);
    position: relative;
}

.section-head {
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: end;
    gap: 24px;
    margin-bottom: 72px;
}
.section-num {
    font-family: var(--font-display);
    font-size: 14px;
    letter-spacing: 0.3em;
    color: var(--brass);
    padding-bottom: 12px;
}
.section-title {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 400;
    font-size: clamp(38px, 5.6vw, 68px);
    line-height: 1;
    margin: 0;
    color: var(--paper);
}
.section-rule {
    height: 1px;
    background: linear-gradient(to right, var(--brass), transparent);
    align-self: end;
    margin-bottom: 18px;
}
.section-lede {
    font-family: var(--font-serif);
    font-size: 18px;
    color: var(--bone);
    max-width: 620px;
    margin: -40px 0 56px;
    line-height: 1.6;
}

/* =========================================================
   SALON
   ========================================================= */
.salon {
    background: linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 100%);
    position: relative;
}
.salon-grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 80px;
    align-items: start;
}
.salon-text p {
    font-family: var(--font-serif);
    font-size: 19px;
    line-height: 1.7;
    color: var(--bone);
    margin: 0 0 22px;
}
.dropcap { position: relative; }
.dropletter {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 88px;
    line-height: 0.85;
    color: var(--brass);
    float: left;
    margin: 6px 14px 0 0;
}
.signature {
    font-style: italic;
    color: var(--brass) !important;
    font-size: 17px !important;
    margin-top: 40px !important;
}

.salon-credentials {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: rgba(200, 155, 90, 0.18);
    border: 1px solid rgba(200, 155, 90, 0.18);
}
.cred-card {
    background: var(--ink-2);
    padding: 36px 28px;
    transition: background 320ms ease, transform 320ms ease;
    position: relative;
}
.cred-card:hover {
    background: var(--ink-3);
    transform: translateY(-2px);
}
.cred-num {
    font-family: var(--font-display);
    font-size: 11px;
    letter-spacing: 0.4em;
    color: var(--brass);
    display: block;
    margin-bottom: 24px;
}
.cred-card h3 {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 500;
    font-size: 22px;
    color: var(--paper);
    margin: 0 0 14px;
}
.cred-card p {
    font-family: var(--font-sans);
    font-size: 14px;
    line-height: 1.6;
    color: var(--bone);
    margin: 0;
    opacity: 0.85;
}

/* =========================================================
   TREATY
   ========================================================= */
.treaty {
    background:
        radial-gradient(circle at 80% 20%, rgba(90, 26, 34, 0.12), transparent 60%),
        var(--ink-2);
    position: relative;
}
.treaty .section-frame { padding-bottom: 140px; }

.treaty-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-top: 1px solid rgba(200, 155, 90, 0.3);
    border-bottom: 1px solid rgba(200, 155, 90, 0.3);
    margin-bottom: 64px;
}
.treaty-tab {
    flex: 1 1 200px;
    padding: 22px 18px;
    color: var(--bone);
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    border-right: 1px solid rgba(200, 155, 90, 0.18);
    transition: color 220ms ease, background 220ms ease;
    position: relative;
}
.treaty-tab:last-child { border-right: 0; }
.treaty-tab::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 2px;
    background: var(--brass);
    transform: scaleX(0);
    transition: transform 320ms ease;
}
.treaty-tab:hover { color: var(--paper); background: rgba(200, 155, 90, 0.04); }
.treaty-tab.is-active {
    color: var(--brass);
    background: rgba(200, 155, 90, 0.06);
}
.treaty-tab.is-active::after { transform: scaleX(1); }

.treaty-pages { position: relative; min-height: 420px; }
.treaty-page {
    display: none;
    grid-template-columns: 1fr 1fr;
    gap: 36px 80px;
    animation: pageFade 520ms ease;
}
.treaty-page.is-active { display: grid; }
@keyframes pageFade {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.treaty-item {
    border-bottom: 1px dashed rgba(200, 155, 90, 0.25);
    padding-bottom: 22px;
}
.item-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 8px;
}
.item-head h3 {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 500;
    font-size: 22px;
    margin: 0;
    color: var(--paper);
}
.item-price {
    font-family: var(--font-display);
    font-size: 16px;
    color: var(--brass);
    letter-spacing: 0.12em;
    flex-shrink: 0;
    border-bottom: 1px dotted var(--brass);
    padding: 0 4px 2px;
}
.item-body {
    font-family: var(--font-serif);
    font-size: 16px;
    line-height: 1.5;
    color: var(--bone);
    margin: 0 0 10px;
}
.item-clause {
    font-family: var(--font-sans);
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--brass-2);
}

.treaty-seal {
    position: absolute;
    right: var(--gutter);
    bottom: 40px;
    opacity: 0.55;
    pointer-events: none;
}
.treaty-seal svg {
    animation: sealSpin 60s linear infinite;
}
@keyframes sealSpin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* =========================================================
   CAPITALS
   ========================================================= */
.capitals {
    background: var(--ink);
    position: relative;
}
.capitals-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1px;
    background: rgba(200, 155, 90, 0.18);
    border: 1px solid rgba(200, 155, 90, 0.18);
    margin-bottom: 56px;
}
.capital {
    background: var(--ink-2);
    padding: 30px 24px;
    text-align: left;
    cursor: pointer;
    transition: background 280ms ease, color 280ms ease;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 160px;
    justify-content: space-between;
}
.capital:hover, .capital.is-active {
    background: var(--ink-3);
}
.capital:hover .capital-line, .capital.is-active .capital-line {
    transform: scaleX(1);
}
.capital:hover .capital-name, .capital.is-active .capital-name {
    color: var(--brass);
}
.capital-name {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 400;
    font-size: 28px;
    color: var(--paper);
    line-height: 1;
    transition: color 280ms ease;
}
.capital-line {
    width: 100%;
    height: 1px;
    background: var(--brass);
    transform: scaleX(0.2);
    transform-origin: left;
    transition: transform 360ms ease;
}
.capital-tag {
    font-family: var(--font-sans);
    font-size: 10px;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: var(--brass);
}

.dossier {
    border: 1px solid rgba(200, 155, 90, 0.3);
    background: linear-gradient(135deg, rgba(244, 234, 215, 0.04), rgba(200, 155, 90, 0.06));
    padding: 36px 40px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 40px;
    align-items: center;
    position: relative;
}
.dossier-stamp {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.45em;
    color: var(--oxblood);
    background: var(--paper);
    padding: 14px 22px;
    border: 1px solid var(--oxblood);
    transform: rotate(-8deg);
    align-self: start;
    margin-top: 6px;
    box-shadow: 0 0 0 1px rgba(90, 26, 34, 0.2) inset;
}
.dossier-body h3 {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 36px;
    margin: 0 0 8px;
    color: var(--paper);
}
.dossier-coord {
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--brass);
    margin: 0 0 14px;
}
.dossier-spirit {
    font-family: var(--font-serif);
    font-size: 17px;
    color: var(--bone);
    margin: 0 0 8px;
}
.dossier-note {
    font-family: var(--font-sans);
    font-size: 12px;
    line-height: 1.6;
    color: var(--bone);
    opacity: 0.6;
    margin: 0;
    max-width: 540px;
}

/* =========================================================
   PROTOCOL
   ========================================================= */
.protocol {
    background:
        linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 100%);
}
.protocol-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: rgba(200, 155, 90, 0.18);
    border: 1px solid rgba(200, 155, 90, 0.18);
}
.protocol-list li {
    background: var(--ink-2);
    padding: 36px 32px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 22px;
    align-items: start;
    transition: background 280ms ease;
}
.protocol-list li:hover { background: var(--ink-3); }
.protocol-num {
    font-family: var(--font-display);
    font-size: 12px;
    letter-spacing: 0.4em;
    color: var(--brass);
    padding-top: 4px;
}
.protocol-text {
    font-family: var(--font-serif);
    font-size: 19px;
    line-height: 1.55;
    color: var(--bone);
}

/* =========================================================
   DISPATCH
   ========================================================= */
.dispatch {
    background: var(--ink-2);
    position: relative;
}
.dispatch::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 80%, rgba(45, 74, 62, 0.22), transparent 55%);
    pointer-events: none;
}
.dispatch .section-frame { position: relative; z-index: 1; }
.dispatch-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.dispatch-text p {
    font-family: var(--font-serif);
    font-size: 19px;
    line-height: 1.7;
    color: var(--bone);
    margin: 0 0 18px;
}
.dispatch-note {
    font-family: var(--font-sans) !important;
    font-size: 12px !important;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--brass) !important;
    margin-top: 28px !important;
}
.dispatch-form { display: flex; flex-direction: column; gap: 12px; }
.dispatch-label {
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--brass);
}
.dispatch-row {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--brass);
}
.dispatch-row input {
    flex: 1;
    background: transparent;
    border: 0;
    color: var(--paper);
    font-family: var(--font-serif);
    font-size: 22px;
    padding: 14px 0;
    outline: none;
}
.dispatch-row input::placeholder {
    color: rgba(216, 205, 180, 0.4);
    font-style: italic;
}
.dispatch-row .btn-primary { flex-shrink: 0; }
.dispatch-feedback {
    min-height: 18px;
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--brass);
    margin: 0;
}

/* =========================================================
   RESERVE
   ========================================================= */
.reserve {
    background: linear-gradient(180deg, var(--ink-2) 0%, var(--ink) 100%);
}
.reserve-form {
    max-width: 880px;
    background: var(--ink-2);
    border: 1px solid rgba(200, 155, 90, 0.22);
    padding: 56px;
    display: flex;
    flex-direction: column;
    gap: 28px;
    position: relative;
}
.reserve-form::before {
    content: "";
    position: absolute;
    top: 16px; left: 16px;
    right: 16px; bottom: 16px;
    border: 1px solid rgba(200, 155, 90, 0.12);
    pointer-events: none;
}
.form-row {
    display: grid;
    gap: 24px;
    position: relative;
}
.form-row.two { grid-template-columns: 1fr 1fr; }
.form-row.three { grid-template-columns: 1fr 1fr 1fr; }
.form-field { display: flex; flex-direction: column; gap: 8px; }
.form-field label {
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--brass);
}
.form-field input,
.form-field select,
.form-field textarea {
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(216, 205, 180, 0.28);
    color: var(--paper);
    font-family: var(--font-serif);
    font-size: 18px;
    padding: 12px 0;
    outline: none;
    transition: border-color 220ms ease;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
    border-color: var(--brass);
}
.form-field select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1 L6 6 L11 1' stroke='%23c89b5a' stroke-width='1.2' fill='none'/></svg>");
    background-repeat: no-repeat;
    background-position: right 4px center;
    padding-right: 24px;
}
.form-field select option { background: var(--ink-2); color: var(--paper); }
.form-field textarea { resize: vertical; min-height: 70px; }

.submit-row {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 24px;
    margin-top: 12px;
}
.form-feedback {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--brass);
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer {
    background: var(--ink);
    border-top: 1px solid rgba(200, 155, 90, 0.18);
    padding: 80px var(--gutter) 30px;
}
.footer-inner {
    max-width: var(--maxw);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 60px;
    align-items: start;
}
.footer-brand {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.footer-brand .brand-name {
    font-family: var(--font-display);
    font-size: 32px;
    letter-spacing: 0.18em;
    color: var(--paper);
}
.footer-tagline {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--brass);
    font-size: 16px;
}
.footer-cols {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}
.footer-col {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-family: var(--font-serif);
    font-size: 15px;
    color: var(--bone);
}
.footer-col a {
    color: var(--bone);
    transition: color 220ms ease;
}
.footer-col a:hover { color: var(--brass); }
.footer-key {
    font-family: var(--font-sans);
    font-size: 10px;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--brass);
    margin-bottom: 6px;
}
.footer-rule {
    max-width: var(--maxw);
    margin: 60px auto 24px;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--brass), transparent);
}
.footer-meta {
    max-width: var(--maxw);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--bone);
    opacity: 0.6;
}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 900ms ease, transform 900ms ease;
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
    .header-inner { grid-template-columns: auto 1fr auto; }
    .primary-nav { display: none; }
    .salon-grid,
    .dispatch-grid,
    .footer-inner {
        grid-template-columns: 1fr;
        gap: 56px;
    }
    .footer-cols { grid-template-columns: 1fr 1fr; }
    .treaty-page { grid-template-columns: 1fr; gap: 28px; }
    .capitals-grid { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
    .dossier { grid-template-columns: 1fr; gap: 20px; }
    .dossier-stamp { justify-self: start; }
}

@media (max-width: 720px) {
    .header-inner { grid-template-columns: auto auto; gap: 16px; }
    .btn-reserve { padding: 9px 14px; font-size: 10px; letter-spacing: 0.22em; }
    .brand-sub { display: none; }
    .hero { padding-top: 100px; }
    .hero-actions { gap: 12px; }
    .btn-primary, .btn-ghost { padding: 14px 22px; flex: 1 1 auto; }
    .hero-meta { grid-template-columns: 1fr; gap: 16px; }
    .salon-credentials { grid-template-columns: 1fr; }
    .protocol-list { grid-template-columns: 1fr; }
    .footer-cols { grid-template-columns: 1fr; }
    .reserve-form { padding: 32px 22px; }
    .form-row.two, .form-row.three { grid-template-columns: 1fr; }
    .submit-row { flex-direction: column !important; align-items: stretch; }
    .section-head { grid-template-columns: 1fr; gap: 12px; }
    .section-rule { display: none; }
    .treaty-tabs { flex-direction: column; }
    .treaty-tab { border-right: 0; border-bottom: 1px solid rgba(200, 155, 90, 0.18); }
    .treaty-seal { display: none; }
    .capital-coords { left: var(--gutter); right: var(--gutter); text-align: left; bottom: 100px; }
    .hero-scroll { display: none; }
    .dropletter { font-size: 64px; }
    .globe-art { width: 140vw; height: 140vw; right: -20%; opacity: 0.35; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001s !important;
        transition-duration: 0.001s !important;
    }
}
