:root{
  --ink:#0a1c28;
  --ink-2:#1f3b4c;
  --muted:#6f8693;
  --line:#e2d6bd;
  --line-2:#cebf9f;
  --paper:#f5efde;
  --paper-2:#ede4cc;
  --chalk:#f9f5ea;
  --ocean:#0d3b50;
  --ocean-2:#154d66;
  --ocean-3:#1a6a86;
  --wave:#2f7a95;
  --brass:#c48a1c;
  --brass-2:#a36e0e;
  --coral:#bd4430;
  --card:#fdfaef;
  --radius:2px;
  --maxw:1160px;
  --font-display: Georgia, "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Cambria, serif;
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
}

body{
  margin:0;
  font-family:var(--font-sans);
  font-size:16.5px;
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  background-image:
    radial-gradient(900px 500px at 90% 0%, rgba(47,122,149,.10), transparent 60%),
    radial-gradient(700px 400px at 0% 15%, rgba(189,68,48,.05), transparent 55%),
    repeating-linear-gradient(0deg, rgba(10,28,40,.012) 0 1px, transparent 1px 3px);
  -webkit-text-size-adjust:100%;
}

img{max-width:100%;height:auto;display:block}

a,button,input,textarea,select,summary,.card,.btn,.faq,.cookie,.cookie-modal .panel,.nav a{
  transition:color .25s ease, background-color .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}

a{
  color:var(--ocean-3);text-decoration:none;
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0 1.5px;background-position:0 100%;background-repeat:no-repeat;
  transition:background-size .35s cubic-bezier(.2,.8,.2,1), color .25s ease, opacity .25s ease;
}
a:hover{color:var(--brass-2);background-size:100% 1.5px}
.btn,.brand,.nav a{background-image:none!important}

a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible{
  outline:2px dashed var(--brass);outline-offset:3px;border-radius:2px;
}

.container{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.75rem 1rem;z-index:100}
.skip-link:focus{left:1rem;top:1rem}

/* Typography */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:.2rem 0 .6rem}
h1{font-size:clamp(2.1rem,4.4vw,3.3rem);line-height:1.08;margin:.2rem 0 .9rem}
h2{font-size:clamp(1.6rem,2.9vw,2.2rem);margin:2.3rem 0 1.2rem;position:relative;padding-bottom:.75rem}
h2::after{content:"";position:absolute;left:0;bottom:0;width:72px;height:3px;background:linear-gradient(90deg,var(--brass),var(--brass-2));border-radius:2px}
.center h2::after{left:50%;transform:translateX(-50%)}
h3{font-size:1.2rem;margin:1.1rem 0 .4rem}
h4{font-size:1rem;margin:.2rem 0 .6rem}
p{margin:.55rem 0}
.lead{font-size:1.15rem;color:var(--ink-2);max-width:62ch;font-family:var(--font-sans)}
.muted{color:var(--muted)}
.center{text-align:center}
hr{border:none;height:1px;background:var(--line-2);margin:2rem 0}

/* Eyebrow tag */
.eyebrow{
  display:inline-block;font-family:var(--font-sans);
  font-size:.72rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass-2);background:rgba(196,138,28,.08);
  padding:.5rem .9rem;margin-bottom:1rem;
  border:1px solid var(--brass);
}

/* Header — chalkboard bar */
.site-header{
  position:sticky;top:0;z-index:20;
  background:linear-gradient(180deg,var(--ocean) 0%, #0a2f40 100%);
  border-bottom:3px solid var(--brass);
  box-shadow:0 8px 22px rgba(10,28,40,.22);
}
.site-header .row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.95rem;padding-bottom:.95rem;position:relative}
.brand{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-weight:700;color:var(--chalk);font-size:1.15rem}
.brand-mark{
  width:44px;height:44px;flex:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'><defs><radialGradient id='bmbg' cx='40%25' cy='30%25' r='80%25'><stop offset='0' stop-color='%231b6a88'/><stop offset='55%25' stop-color='%230e3b50'/><stop offset='100%25' stop-color='%23061f2b'/></radialGradient><linearGradient id='bmline' x1='0' y1='0' x2='1' y2='1'><stop offset='0' stop-color='%23efb43a'/><stop offset='55%25' stop-color='%23c48a1c'/><stop offset='100%25' stop-color='%23875a08'/></linearGradient></defs><circle cx='24' cy='24' r='22' fill='url(%23bmbg)' stroke='url(%23bmline)' stroke-width='2'/><path d='M7 32 Q 12 35 17 32 T 27 32 T 37 32 T 42 32' fill='none' stroke='url(%23bmline)' stroke-width='1.2' stroke-linecap='round' opacity='.55'/><path d='M10 36 Q 15 38 20 36 T 30 36 T 40 36' fill='none' stroke='url(%23bmline)' stroke-width='1' stroke-linecap='round' opacity='.35'/><g fill='none' stroke='url(%23bmline)' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'><path d='M10 22 Q 16 13 26 16 Q 33 19 33 22 Q 33 25 26 28 Q 16 31 10 22 Z'/><path d='M33 22 L 41 16 L 39 22 L 41 28 Z'/><path d='M19 18 Q 22 21 25 19'/><path d='M27 22 L 30 22'/></g><circle cx='14.5' cy='20.5' r='1.2' fill='%23efb43a'/><circle cx='14.5' cy='20.5' r='.4' fill='%23061f2b'/><circle cx='9' cy='12' r='1.1' fill='%23f9f5ea' opacity='.55'/><circle cx='6' cy='16' r='.7' fill='%23f9f5ea' opacity='.35'/></svg>");
  background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 2px 5px rgba(0,0,0,.45));
  transition:transform .4s cubic-bezier(.34,1.4,.5,1);
}
.brand:hover .brand-mark{transform:rotate(-6deg) scale(1.05)}

.nav{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center}
.nav a{
  color:rgba(249,245,234,.78);font-weight:600;font-size:.95rem;
  letter-spacing:.02em;padding:.45rem .15rem;position:relative;font-family:var(--font-sans);
}
.nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;
  background:var(--brass);border-radius:2px;
  transition:right .35s cubic-bezier(.2,.8,.2,1), opacity .25s ease;opacity:0;
}
.nav a:hover{color:var(--chalk)}
.nav a:hover::after{right:0;opacity:.7}
.nav a.active,.nav a[aria-current="page"]{color:#ffffff}
.nav a.active::after,.nav a[aria-current="page"]::after{right:0;opacity:1}

.nav-toggle{
  display:none;background:transparent;border:1px solid rgba(249,245,234,.4);border-radius:3px;
  width:42px;height:42px;cursor:pointer;position:relative;padding:0;
}
.nav-toggle-bar{
  display:block;position:absolute;left:9px;right:9px;height:2px;background:var(--chalk);border-radius:1px;
  transition:transform .2s ease,opacity .2s ease,top .2s ease;
}
.nav-toggle-bar:nth-child(1){top:13px}
.nav-toggle-bar:nth-child(2){top:20px}
.nav-toggle-bar:nth-child(3){top:27px}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){top:20px;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){top:20px;transform:rotate(-45deg)}

@media (max-width:820px){
  .site-header .container{padding-left:1.5rem;padding-right:1.5rem}
  .site-header .row{padding-top:.75rem;padding-bottom:.75rem}
  .nav-toggle{display:block}
  .nav{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:var(--ocean);border-bottom:3px solid var(--brass);
    padding:.4rem 1.25rem 1rem;display:none;
  }
  .nav.open{display:flex}
  .nav a{padding:.85rem 0;width:100%;border-bottom:1px solid rgba(249,245,234,.12)}
  .nav a:last-child{border-bottom:none}
  .nav a::after{display:none}
}
@media (max-width:400px){.site-header .container{padding-left:1.15rem;padding-right:1.15rem}}

section[id]{scroll-margin-top:90px}

/* Hero */
.hero{padding:4.5rem 0 6rem;position:relative;overflow:hidden}
.hero > .container{position:relative;z-index:2}
.hero::after{
  content:"";position:absolute;left:-5%;right:-5%;bottom:-2px;height:56px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 56' preserveAspectRatio='none'><path d='M0 28 Q 120 52, 240 28 T 480 28 T 720 28 T 960 28 T 1200 28 T 1440 28 V56 H0 Z' fill='%23ede4cc'/></svg>");
  background-size:1440px 56px;background-repeat:repeat-x;
  animation:waveSlide 18s linear infinite;
  pointer-events:none;z-index:1;
}
.hero::before{
  content:"";position:absolute;left:-5%;right:-5%;bottom:14px;height:36px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 36' preserveAspectRatio='none'><path d='M0 18 Q 120 36, 240 18 T 480 18 T 720 18 T 960 18 T 1200 18 T 1440 18 V36 H0 Z' fill='%23e0d4bc' fill-opacity='.55'/></svg>");
  background-size:1440px 36px;background-repeat:repeat-x;
  animation:waveSlideRev 24s linear infinite;
  pointer-events:none;z-index:1;
}
@keyframes waveSlide{0%{background-position:0 0}100%{background-position:-1440px 0}}
@keyframes waveSlideRev{0%{background-position:0 0}100%{background-position:1440px 0}}

.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:3rem;align-items:center}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr}}
.hero-img{
  width:100%;max-width:500px;aspect-ratio:4/3;object-fit:cover;
  border:1px solid var(--line-2);background:#eaf2f7;
  box-shadow:0 2px 0 var(--brass),0 22px 48px rgba(10,28,40,.18);
  border-radius:2px;display:block;margin-left:auto;
  filter:saturate(1.05);
}

/* Hero bubbles */
.hero-bubbles{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bubble{
  position:absolute;bottom:-24px;left:var(--b-left,50%);
  width:var(--b-size,10px);height:var(--b-size,10px);border-radius:50%;
  background:radial-gradient(circle at 32% 30%, rgba(255,255,255,.92), rgba(47,122,149,.25) 60%, rgba(13,59,80,.15));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.35);
  opacity:0;
  animation:bubbleRise var(--b-duration,9s) var(--b-delay,0s) linear infinite;
}
@keyframes bubbleRise{
  0%  {transform:translate3d(0,0,0) scale(.8);opacity:0}
  8%  {opacity:.55}
  50% {transform:translate3d(10px,-35vh,0) scale(1)}
  92% {opacity:.35}
  100%{transform:translate3d(-6px,-72vh,0) scale(1.1);opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .hero::before,.hero::after{animation:none}
  .bubble{display:none}
}

/* Sections with alternating paper shades */
section{padding:4rem 0;border-top:1px solid var(--line-2);position:relative}
section:first-of-type{border-top:none}
section:nth-of-type(even){background:var(--paper-2)}

/* Grid */
.grid{display:grid;gap:1.5rem}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:880px){.grid.cols-3,.grid.cols-4{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}

/* Cards — tezgah etiketi */
.card{
  background:var(--card);border:1px solid var(--line);
  padding:1.5rem 1.35rem 1.35rem;border-radius:2px;
  box-shadow:0 1px 2px rgba(10,28,40,.06),0 8px 22px rgba(10,28,40,.07);
  position:relative;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brass),var(--brass-2));
  opacity:.85;
}
.card h3{margin-top:.3rem}
.card{transform-origin:top center}
.card:hover{
  box-shadow:0 2px 4px rgba(10,28,40,.08),0 26px 48px rgba(10,28,40,.16);
  border-color:var(--line-2);
  animation:tagSwing .85s cubic-bezier(.36,.07,.19,.97);
  transform:translateY(-4px);
}
@keyframes tagSwing{
  0%  {transform:translateY(-4px) rotate(0)}
  15% {transform:translateY(-4px) rotate(-1.2deg)}
  30% {transform:translateY(-4px) rotate(.9deg)}
  45% {transform:translateY(-4px) rotate(-.6deg)}
  60% {transform:translateY(-4px) rotate(.35deg)}
  75% {transform:translateY(-4px) rotate(-.15deg)}
  100%{transform:translateY(-4px) rotate(0)}
}

.label-tag{
  display:inline-block;font-family:var(--font-sans);font-size:.7rem;
  font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ocean);background:var(--paper-2);
  padding:.3rem .65rem;margin-bottom:.65rem;
  border-left:3px solid var(--brass);
}

.card-img{
  width:100%;aspect-ratio:4/3;object-fit:cover;
  border:1px solid var(--line-2);border-radius:2px;
  background:#eaf2f7;margin-bottom:.95rem;
  filter:saturate(1.05);
}

.split{display:grid;grid-template-columns:280px 1fr;gap:1.75rem;align-items:start}
@media (max-width:640px){.split{grid-template-columns:1fr}}
.split img{
  width:100%;aspect-ratio:4/3;object-fit:cover;
  border:1px solid var(--line-2);background:#eaf2f7;
  box-shadow:0 1px 2px rgba(10,28,40,.06),0 14px 28px rgba(10,28,40,.12);
  border-radius:2px;
}

/* Price table — chalkboard */
.table-wrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  background:var(--ocean);
  background-image:
    radial-gradient(800px 300px at 20% 0%, rgba(47,122,149,.3), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.012) 0 2px, transparent 2px 6px);
  border:1px solid #05212e;
  box-shadow:0 4px 0 var(--brass-2),0 22px 40px rgba(10,28,40,.3);
  padding:.6rem;
  border-radius:2px;
}
.table-wrap::-webkit-scrollbar{height:10px}
.table-wrap::-webkit-scrollbar-track{background:rgba(255,255,255,.06)}
.table-wrap::-webkit-scrollbar-thumb{background:var(--brass);border-radius:999px}
.price-table{
  width:100%;border-collapse:collapse;background:transparent;
  color:var(--chalk);font-family:var(--font-display);
}
.price-table th,.price-table td{padding:1rem 1.15rem;text-align:left;white-space:nowrap;border-bottom:1px dashed rgba(249,245,234,.2)}
.price-table th{font-family:var(--font-sans);font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);border-bottom:1px solid rgba(196,138,28,.4)}
.price-table td{font-size:1.08rem}
.price-table tr:last-child td{border-bottom:none}
.price-table tr:hover td{background:rgba(249,245,234,.04)}

.callout{
  background:var(--paper);
  border:1px solid var(--coral);
  border-left:6px solid var(--coral);
  color:#5c1d12;
  padding:1rem 1.2rem;border-radius:2px;
  font-family:var(--font-sans);
}

/* Calculator */
.calc{
  background:var(--card);border:1px solid var(--line);
  border-radius:2px;padding:1.75rem;
  box-shadow:0 1px 2px rgba(10,28,40,.06),0 14px 34px rgba(10,28,40,.08);
  position:relative;
}
.calc::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brass),var(--brass-2));
}
.calc .row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
@media (max-width:560px){.calc .row{grid-template-columns:1fr}}
.calc label{display:block;font-family:var(--font-sans);font-weight:800;margin-bottom:.45rem;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}

/* Custom select */
.calc select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  width:100%;padding:.95rem 2.8rem .95rem 1.1rem;font-family:inherit;font-size:1rem;color:var(--ink);
  background:#fff;border:1px solid var(--line-2);border-radius:2px;cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  background-image:
    linear-gradient(180deg,#ffffff,#f6eede),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%23a36e0e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");
  background-repeat:no-repeat,no-repeat;
  background-position:0 0,right 14px center;
  background-size:100% 100%,16px 16px;
}
.calc select:hover{border-color:var(--brass)}
.calc select:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(196,138,28,.2),inset 0 1px 0 rgba(255,255,255,.8);outline:none}

/* Range slider */
.calc input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;width:100%;padding:.95rem 0}
.calc input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:0;background:linear-gradient(90deg,var(--brass-2),var(--brass))}
.calc input[type=range]::-moz-range-track{height:6px;border-radius:0;background:linear-gradient(90deg,var(--brass-2),var(--brass))}
.calc input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:0;
  background:var(--ocean);border:3px solid var(--brass);box-shadow:0 2px 6px rgba(10,28,40,.3);
  margin-top:-8px;cursor:pointer;transform:rotate(45deg);transition:transform .2s ease;
}
.calc input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:0;background:var(--ocean);border:3px solid var(--brass);box-shadow:0 2px 6px rgba(10,28,40,.3);cursor:pointer;transform:rotate(45deg)}
.calc input[type=range]:hover::-webkit-slider-thumb{transform:rotate(45deg) scale(1.1)}

.calc .out{
  margin-top:1.3rem;padding:1.15rem 1.3rem;
  background:var(--ocean);color:var(--chalk);
  font-family:var(--font-display);font-size:1.1rem;font-weight:700;
  border-left:4px solid var(--brass);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}

/* FAQ */
details.faq{
  background:var(--card);border:1px solid var(--line);
  padding:1.05rem 1.25rem;margin-bottom:.75rem;border-radius:2px;
  border-left:4px solid var(--brass);
}
details.faq > summary{cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:1.08rem;list-style:none;color:var(--ink);padding-right:2rem}
details.faq > summary::-webkit-details-marker{display:none}
details.faq > summary::after{
  content:"+";float:right;color:var(--brass-2);font-weight:700;font-size:1.5rem;line-height:1;
  transition:transform .3s ease;display:inline-block;transform-origin:center;margin-top:-.1rem;
}
details.faq[open] > summary{color:var(--brass-2)}
details.faq[open] > summary::after{transform:rotate(45deg)}
details.faq > p{color:var(--ink-2);margin-top:.7rem}
details.faq .faq-inner{overflow:hidden;transition:height .42s cubic-bezier(.2,.8,.2,1)}
details.faq .faq-inner > p:first-child{margin-top:.7rem}
details.faq.faq-animating .faq-inner{will-change:height}

/* Buttons — serious seafood tag */
.btn{
  display:inline-block;padding:.95rem 1.7rem;font-family:var(--font-sans);font-weight:800;
  font-size:.88rem;letter-spacing:.08em;text-transform:uppercase;
  background:var(--ocean);color:var(--chalk);border:1px solid var(--ocean);
  border-radius:2px;cursor:pointer;text-decoration:none;
  box-shadow:0 3px 0 var(--brass-2),0 10px 22px rgba(10,28,40,.22);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn + .btn{margin-left:1rem}
.btn{margin-top:.5rem;margin-bottom:.5rem}
.btn:hover{background:var(--ocean-2);transform:translateY(-1px);box-shadow:0 4px 0 var(--brass-2),0 14px 28px rgba(10,28,40,.28);color:#fff}
.btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--brass-2),0 4px 8px rgba(10,28,40,.18)}
.btn.secondary{background:transparent;color:var(--ocean);border-color:var(--ocean);box-shadow:0 3px 0 var(--brass-2)}
.btn.secondary:hover{background:var(--ocean);color:var(--chalk)}
.btn.ghost{background:var(--paper);color:var(--ink);border-color:var(--line-2);box-shadow:0 3px 0 var(--line-2)}
.btn.ghost:hover{background:var(--chalk);border-color:var(--brass);color:var(--ocean)}

/* Form — paper receipt */
form.contact{
  background:var(--card);border:1px solid var(--line-2);
  padding:2rem 1.9rem;position:relative;border-radius:2px;
  box-shadow:0 3px 0 var(--brass-2),0 24px 48px rgba(10,28,40,.14);
}
form.contact h3{margin-top:0}
.field{margin-bottom:1.15rem}
.field label{display:block;font-family:var(--font-sans);font-weight:800;margin-bottom:.4rem;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-2)}
.field input:not([type=checkbox]):not([type=radio]),.field textarea{
  width:100%;padding:.9rem 1rem;border:1px solid var(--line-2);border-radius:2px;
  font-family:inherit;font-size:1rem;background:#fff;color:var(--ink);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.field input:not([type=checkbox]):not([type=radio]):focus,.field textarea:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(196,138,28,.2),inset 0 1px 0 rgba(255,255,255,.8);outline:none}
.field input[type=checkbox]{
  flex:none;width:20px;height:20px;margin:0;
  accent-color:var(--brass);cursor:pointer;
}
.field textarea{min-height:150px;resize:vertical}
.field .help{font-size:.82rem;color:var(--muted);margin-top:.3rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-msg{margin-top:1rem;padding:.9rem 1.1rem;border-radius:2px;display:none;font-family:var(--font-sans);font-size:.95rem}
.form-msg.show{display:block}
.form-msg.ok{background:#e9f3ea;color:#174e2c;border:1px solid #b8dbc1;border-left:4px solid #2b7a3f}
.form-msg.err{background:#faeae8;color:#6e1e15;border:1px solid #eec5bf;border-left:4px solid var(--coral)}

/* Contact info cards */
.contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.3rem}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.contact-grid{grid-template-columns:1fr}}
.info-card{
  background:var(--card);border:1px solid var(--line);
  padding:1.5rem 1.35rem;position:relative;overflow:hidden;border-radius:2px;
  box-shadow:0 1px 2px rgba(10,28,40,.06),0 10px 22px rgba(10,28,40,.08);
}
.info-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--brass),var(--brass-2));
}
.info-card h3{margin:.45rem 0 .4rem;font-size:1.1rem;font-family:var(--font-display);word-break:break-word}
.info-card p{margin:.2rem 0;color:var(--ink-2);font-size:.95rem}
.info-card .ic-label{display:block;font-family:var(--font-sans);font-size:.7rem;color:var(--brass-2);text-transform:uppercase;letter-spacing:.16em;font-weight:800;margin-bottom:.2rem}
.info-card:hover{transform:translateY(-3px);box-shadow:0 2px 4px rgba(10,28,40,.08),0 22px 36px rgba(10,28,40,.14)}

.contact-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:start}
@media (max-width:900px){.contact-layout{grid-template-columns:1fr}}

.trust-list{list-style:none;padding:0;margin:1.2rem 0 0}
.trust-list li{
  position:relative;padding:.75rem 0 .75rem 1.8rem;
  border-bottom:1px dashed var(--line-2);color:var(--ink-2);
}
.trust-list li:last-child{border-bottom:none}
.trust-list li::before{
  content:"";position:absolute;left:0;top:1.1rem;width:12px;height:12px;
  background:linear-gradient(135deg,var(--brass),var(--brass-2));
  transform:rotate(45deg);
}

/* Footer — ocean depth */
.site-footer{
  margin-top:4.5rem;padding:4rem 0 2rem;
  background:var(--ocean);color:#c4d8e0;
  background-image:
    radial-gradient(800px 400px at 80% 120%, rgba(196,138,28,.09), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.018) 0 2px, transparent 2px 6px);
  border-top:3px solid var(--brass);
  position:relative;
}
.site-footer .grid{grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2.5rem}
@media (max-width:880px){.site-footer .grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.site-footer .grid{grid-template-columns:1fr}}
.site-footer h4{margin:.2rem 0 .8rem;color:var(--chalk);font-family:var(--font-display);font-size:1.15rem}
.site-footer p{color:#b6ced6;margin:.3rem 0}
.site-footer a{
  color:#dce8ed;
  background-image:linear-gradient(var(--brass),var(--brass));
  background-size:0 1px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .35s cubic-bezier(.2,.8,.2,1), color .25s;
}
.site-footer a:hover{background-size:100% 1px;color:#ffffff}
.legal{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;padding-top:1.3rem;color:#8aa3ad;font-size:.88rem;text-align:center;font-family:var(--font-sans)}

/* Cookie banner */
.cookie{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:50;
  background:var(--card);border:1px solid var(--line-2);
  box-shadow:0 3px 0 var(--brass-2),0 22px 50px rgba(10,28,40,.3);
  padding:1.25rem 1.35rem;max-width:680px;margin:0 auto;display:none;border-radius:2px;
}
.cookie.show{display:block;animation:slideUp .4s cubic-bezier(.2,.8,.2,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.cookie h3{margin:0 0 .3rem;font-size:1.1rem;font-family:var(--font-display)}
.cookie p{margin:.2rem 0 .9rem;color:var(--ink-2);font-size:.95rem}
.cookie .actions{display:flex;flex-wrap:wrap;gap:.55rem}
.cookie .actions .btn{padding:.65rem 1.15rem;font-size:.78rem;box-shadow:0 2px 0 var(--brass-2)}

.cookie-modal{position:fixed;inset:0;background:rgba(10,28,40,.68);display:none;align-items:center;justify-content:center;z-index:60;padding:1rem}
.cookie-modal.show{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.cookie-modal .panel{
  background:var(--card);max-width:560px;width:100%;padding:1.8rem;
  border:1px solid var(--line-2);border-radius:2px;
  box-shadow:0 3px 0 var(--brass-2),0 30px 60px rgba(0,0,0,.4);
}
.cookie-modal h3{margin-top:0;font-family:var(--font-display);font-size:1.3rem}
.toggle{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;border-bottom:1px solid var(--line);gap:1rem}
.toggle:last-of-type{border-bottom:none}
.toggle small{color:var(--muted);display:block;margin-top:.15rem;font-size:.85rem}
.toggle strong{font-family:var(--font-display);font-size:1.02rem}

/* Thematic reveal — animation-based, no pre-transition flicker */
html:not(.js) [class*="reveal-"]{opacity:1!important}
.reveal-tag,.reveal-wave,.reveal-stamp,.reveal-rise,.reveal-slide,.reveal-chalk{opacity:0;will-change:transform,opacity,filter,clip-path}

.reveal-tag.in{animation:revealTag .85s cubic-bezier(.34,1.4,.5,1) both;animation-delay:var(--r-delay,0s)}
@keyframes revealTag{
  0%  {opacity:0;transform:translateY(-34px) rotate(-3deg);transform-origin:top center}
  55% {opacity:1;transform:translateY(2px) rotate(1deg)}
  75% {transform:translateY(0) rotate(-.4deg)}
  100%{opacity:1;transform:translateY(0) rotate(0)}
}

.reveal-wave.in{animation:revealWave 1.1s cubic-bezier(.7,0,.25,1) both;animation-delay:var(--r-delay,0s)}
@keyframes revealWave{
  0%  {opacity:0;clip-path:polygon(0 0, 0 0, 0 100%, 0 100%)}
  30% {opacity:1}
  100%{opacity:1;clip-path:polygon(0 0, 100% 0, 100% 100%, 0 100%)}
}

.reveal-stamp.in{animation:revealStamp .7s cubic-bezier(.2,.9,.2,1.05) both;animation-delay:var(--r-delay,0s)}
@keyframes revealStamp{
  0%  {opacity:0;transform:scale(.92);filter:blur(6px)}
  60% {opacity:1;transform:scale(1.01);filter:blur(0)}
  100%{opacity:1;transform:scale(1);filter:none}
}

.reveal-rise.in{animation:revealRise .75s cubic-bezier(.2,.8,.2,1) both;animation-delay:var(--r-delay,0s)}
@keyframes revealRise{
  from{opacity:0;transform:translateY(28px)}
  to  {opacity:1;transform:none}
}

.reveal-slide.in{animation:revealSlide .55s cubic-bezier(.2,.8,.2,1) both;animation-delay:var(--r-delay,0s)}
@keyframes revealSlide{
  from{opacity:0;transform:translateX(-16px)}
  to  {opacity:1;transform:none}
}

.reveal-chalk.in{animation:revealChalk .8s cubic-bezier(.2,.8,.2,1) both;animation-delay:var(--r-delay,0s)}
@keyframes revealChalk{
  0%  {opacity:0;transform:translateX(-14px);filter:blur(5px)}
  40% {opacity:.7}
  100%{opacity:1;transform:none;filter:blur(0)}
}

@media (prefers-reduced-motion:reduce){
  [class*="reveal-"]{opacity:1!important;animation:none!important;clip-path:none!important;filter:none!important;transform:none!important}
}

/* Utilities */
.mt-0{margin-top:0}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.pill{display:inline-block;background:var(--paper-2);color:var(--brass-2);padding:.3rem .7rem;font-size:.78rem;border:1px solid var(--brass);font-weight:800;letter-spacing:.08em;text-transform:uppercase}
