/* =====================================================================
   Δικηγορικό Γραφείο Γεωργίου Ανδρέα, Αγρίνιο
   Design language: "ήσυχο κύρος" / quiet authority.
   Ink-navy + parchment + brass. Cormorant Garamond + Commissioner.
   ===================================================================== */

:root{
  --navy:#15233B;
  --navy-2:#1C2C49;
  --navy-deep:#101B2E;
  --ivory:#F6F1E7;
  --ivory-2:#FBF8F2;
  --paper:#FFFFFF;
  --card:#FCFAF4;
  --brass:#B08D4C;
  --brass-light:#C9A86A;
  --brass-deep:#8A6B2F;
  --oxblood:#6E2233;
  --ink:#1B2230;
  --ink-soft:#3A4150;
  --muted:#5C6577;
  --muted-2:#7A8295;
  --line:#E4DCCB;
  --line-navy:rgba(201,168,106,.22);
  --shadow-sm:0 2px 10px rgba(20,30,55,.06);
  --shadow:0 18px 50px -22px rgba(16,27,46,.45);
  --shadow-lg:0 40px 90px -40px rgba(16,27,46,.6);
  --r:12px;
  --r-lg:18px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Commissioner",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--ivory);
  font-size:17px;line-height:1.7;font-weight:400;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--navy);margin:0 0 .4em;letter-spacing:.002em;}
h1{font-size:clamp(2.5rem,5.6vw,4.5rem);}
h2{font-size:clamp(2rem,3.8vw,3.05rem);}
h3{font-size:clamp(1.35rem,2vw,1.7rem);}
p{margin:0 0 1.1em;}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---- shared bits ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.62em;font-family:var(--sans);
  font-size:.72rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--brass-deep);margin:0 0 1.1rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);display:inline-block;}
.eyebrow--light{color:var(--brass-light);}
.eyebrow--center{justify-content:center;}
.eyebrow--center::after{content:"";width:26px;height:1px;background:var(--brass);display:inline-block;}
.lead{font-size:1.18rem;color:var(--ink-soft);line-height:1.66;}
.ink-rule{width:54px;height:2px;background:var(--brass);border:0;margin:1.5rem 0;}
.center{text-align:center;}
.center .eyebrow{justify-content:center;}

/* =====================================================================
   BUTTONS - one size via .btn; modifiers scale both sides equally
   ===================================================================== */
.btn{
  --bpadx:1.5em;--bpady:.85em;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--sans);font-size:.95rem;font-weight:600;letter-spacing:.02em;
  padding:var(--bpady) var(--bpadx);border-radius:var(--r);border:1.5px solid transparent;
  cursor:pointer;transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  line-height:1.1;white-space:nowrap;text-align:center;
}
.btn svg{width:1.12em;height:1.12em;flex:0 0 auto;}
.btn--primary{background:var(--brass);color:#fff;border-color:var(--brass);box-shadow:0 10px 24px -12px rgba(138,107,47,.85);}
.btn--primary:hover{background:var(--brass-deep);border-color:var(--brass-deep);transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(138,107,47,.95);}
.btn--navy{background:var(--navy);color:#fff;border-color:var(--navy);}
.btn--navy:hover{background:var(--navy-2);transform:translateY(-2px);}
.btn--ghost{background:transparent;color:var(--navy);border-color:rgba(21,35,59,.28);}
.btn--ghost:hover{border-color:var(--navy);background:rgba(21,35,59,.04);transform:translateY(-2px);}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn--ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px);}
.btn--block{width:100%;}
.btn--lg{--bpadx:1.9em;--bpady:1.02em;font-size:1.02rem;}

/* =====================================================================
   HEADER
   ===================================================================== */
.topbar{background:var(--navy-deep);color:#cdd6e6;font-size:.82rem;letter-spacing:.02em;}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:42px;padding-top:6px;padding-bottom:6px;}
.topbar a{color:#dbe2ee;display:inline-flex;align-items:center;gap:.5em;transition:color .2s;}
.topbar a:hover{color:var(--brass-light);}
.topbar svg{width:15px;height:15px;color:var(--brass-light);}
.topbar .tb-left{display:inline-flex;align-items:center;gap:.5em;color:#aab4c8;}
.topbar .tb-right{display:inline-flex;align-items:center;gap:20px;}

.site-header{position:sticky;top:0;z-index:60;background:rgba(246,241,231,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav{max-width:var(--maxw);margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{display:inline-flex;align-items:center;gap:13px;}
.brand img{width:46px;height:46px;}
.brand .bt{display:flex;flex-direction:column;line-height:1;}
.brand .bt b{font-family:var(--serif);font-weight:600;font-size:1.32rem;color:var(--navy);letter-spacing:.01em;}
.brand .bt small{font-family:var(--sans);font-size:.64rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-deep);margin-top:5px;}

.nav-links{list-style:none;display:flex;align-items:center;gap:6px;margin:0;padding:0;}
.nav-links a:not(.btn){
  position:relative;font-size:.95rem;font-weight:500;color:var(--ink-soft);
  padding:9px 14px;border-radius:8px;transition:color .2s;letter-spacing:.01em;
}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1.5px;
  background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease);
}
.nav-links a:not(.btn):hover{color:var(--navy);}
.nav-links a:not(.btn):hover::after,
.nav-links a:not(.btn).active::after{transform:scaleX(1);}
.nav-links a:not(.btn).active{color:var(--navy);font-weight:600;}
.nav-links .btn{margin-left:8px;}

.nav-cta{display:flex;align-items:center;gap:10px;}
.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:44px;border:1.5px solid rgba(21,35,59,.2);border-radius:10px;background:transparent;color:var(--navy);cursor:pointer;}
.nav-toggle svg{width:22px;height:22px;}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;background:var(--navy);color:#eef2f8;overflow:hidden;}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1100px 520px at 78% -8%,rgba(201,168,106,.16),transparent 60%),
    radial-gradient(800px 600px at 6% 110%,rgba(28,44,73,.9),transparent 60%),
    linear-gradient(180deg,var(--navy-deep),var(--navy) 45%,var(--navy-2));
}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:100% 7px;mix-blend-mode:overlay;pointer-events:none;}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.06fr .94fr;gap:58px;align-items:center;padding-top:88px;padding-bottom:92px;}
.hero-copy{max-width:600px;}
.hero h1{color:#fff;font-weight:600;}
.hero h1 em{font-style:italic;color:var(--brass-light);}
.hero .lead{color:#c4cde0;font-size:1.2rem;max-width:520px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line-navy);}
.hero-trust span{display:inline-flex;align-items:center;gap:.55em;font-size:.9rem;color:#aebbd2;}
.hero-trust svg{width:17px;height:17px;color:var(--brass-light);flex:0 0 auto;}

.hero-figure{position:relative;}
.hero-figure .frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid rgba(201,168,106,.32);box-shadow:var(--shadow-lg);
}
.hero-figure .frame img{width:100%;height:540px;object-fit:cover;}
.hero-figure .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(16,27,46,.5));}
.hero-figure .tag{
  position:absolute;left:-22px;bottom:34px;z-index:3;background:var(--ivory);color:var(--navy);
  padding:16px 20px;border-radius:14px;box-shadow:var(--shadow);max-width:230px;border-left:3px solid var(--brass);
}
.hero-figure .tag b{font-family:var(--serif);font-size:1.5rem;display:block;line-height:1;color:var(--navy);}
.hero-figure .tag small{display:block;font-size:.78rem;color:var(--muted);margin-top:6px;letter-spacing:.02em;}
.hero-figure .seal{position:absolute;top:-20px;right:-16px;width:74px;height:74px;z-index:3;filter:drop-shadow(0 12px 22px rgba(0,0,0,.4));}

/* =====================================================================
   SECTIONS
   ===================================================================== */
.section{padding:96px 0;position:relative;}
.section--tight{padding:64px 0;}
.section--cream{background:var(--ivory);}
.section--paper{background:var(--ivory-2);}
.section--navy{background:var(--navy);color:#e7ecf4;}
.section--navy h1,.section--navy h2,.section--navy h3{color:#fff;}
.section--navy .lead{color:#bcc6da;}
.sec-head{max-width:660px;margin:0 0 52px;}
.sec-head.center{margin-left:auto;margin-right:auto;}
.sec-head p{color:var(--muted);font-size:1.12rem;margin-bottom:0;}
.section--navy .sec-head p{color:#b4bed3;}

/* intro split (home) */
.intro{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.intro-figure{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);}
.intro-figure img{width:100%;height:100%;min-height:430px;object-fit:cover;}
.intro-figure .badge{
  position:absolute;right:18px;bottom:18px;background:var(--navy);color:#fff;
  border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);
}
.intro-figure .badge svg{width:26px;height:26px;color:var(--brass-light);}
.intro-figure .badge b{font-family:var(--serif);font-size:1.05rem;line-height:1.1;font-weight:600;}
.intro-figure .badge small{display:block;font-size:.74rem;color:#aab4c8;letter-spacing:.02em;}
.dropcap::first-letter{font-family:var(--serif);font-size:3.5em;line-height:.74;float:left;margin:.06em .12em 0 0;color:var(--brass-deep);font-weight:600;}
.signature{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--navy);margin-top:.3em;}
.signature small{display:block;font-family:var(--sans);font-style:normal;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px;}

/* values - typographic numbered index (no glyph-pictures) */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.values--4{grid-template-columns:repeat(4,1fr);}
.value{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;
  box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;
}
.value:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--brass-light);}
.value .num{font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--brass-deep);letter-spacing:.12em;}
.value .num::after{content:"";display:block;width:34px;height:2px;background:var(--brass);margin:14px 0 18px;}
.value h3{color:var(--navy);margin-bottom:.4em;}
.value p{color:var(--muted);font-size:1rem;margin-bottom:0;}

/* practice areas - editorial index */
.areas{border-top:1px solid var(--line);}
.area{
  display:grid;grid-template-columns:88px 1fr auto;gap:28px;align-items:center;
  padding:30px 8px;border-bottom:1px solid var(--line);transition:background .25s,padding .25s;
}
.area:hover{background:rgba(176,141,76,.05);}
.area .idx{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--brass-deep);}
.area .body h3{margin:0 0 .25em;color:var(--navy);}
.area .body p{margin:0;color:var(--muted);font-size:1.01rem;max-width:560px;}
.area .go{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line);color:var(--brass-deep);transition:all .25s var(--ease);flex:0 0 auto;}
.area .go svg{width:20px;height:20px;}
.area:hover .go{background:var(--navy);border-color:var(--navy);color:var(--brass-light);transform:rotate(-45deg);}

/* navy feature band (image + copy) */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.feature--reverse .feature-fig{order:2;}
.feature-fig{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line-navy);}
.feature-fig img{width:100%;height:460px;object-fit:cover;}
.feature ul{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:16px;}
.feature li{display:flex;gap:14px;align-items:flex-start;}
.feature li svg{width:22px;height:22px;color:var(--brass-light);flex:0 0 auto;margin-top:3px;}
.feature li b{display:block;color:#fff;font-weight:600;font-size:1.05rem;}
.feature li span{color:#b4bed3;font-size:.98rem;}

/* steps / approach */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:st;}
.step-card{position:relative;padding:32px 24px;border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.step-card .sn{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--brass);line-height:1;}
.step-card h3{font-size:1.25rem;margin:.45em 0 .35em;}
.step-card p{color:var(--muted);font-size:.98rem;margin:0;}

/* CTA band over photo */
.cta-band{position:relative;color:#fff;overflow:hidden;border-radius:0;background-color:var(--navy-deep);}
.cta-band .bg{position:absolute;inset:0;}
.cta-band .bg img{width:100%;height:100%;object-fit:cover;}
.cta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,27,46,.94),rgba(21,35,59,.82) 55%,rgba(28,44,73,.7));}
.cta-band .container{position:relative;z-index:2;text-align:center;padding:84px 28px;}
.cta-band h2{color:#fff;}
.cta-band p{color:#cdd6e6;max-width:560px;margin:0 auto 28px;font-size:1.14rem;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* mini map block (home) */
.mapblock{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center;}
.mapblock .map-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#dfe6ee;min-height:340px;}
.mapblock iframe{width:100%;height:100%;min-height:360px;border:0;display:block;}
.contact-line{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px;}
.contact-line svg{width:22px;height:22px;color:var(--brass-deep);flex:0 0 auto;margin-top:3px;}
.contact-line b{display:block;color:var(--navy);font-weight:600;}
.contact-line span,.contact-line a{color:var(--muted);}
.contact-line a:hover{color:var(--brass-deep);}

/* =====================================================================
   PAGE HERO (interior pages)
   ===================================================================== */
.page-hero{position:relative;background:var(--navy);color:#eef2f8;overflow:hidden;}
.page-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 420px at 84% -20%,rgba(201,168,106,.16),transparent 60%),
  linear-gradient(180deg,var(--navy-deep),var(--navy-2));}
.page-hero .container{position:relative;z-index:2;padding:74px 28px 78px;max-width:860px;}
.page-hero h1{color:#fff;margin-bottom:.25em;}
.page-hero p{color:#c0cae0;font-size:1.18rem;max-width:620px;margin:0;}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.82rem;color:#93a0ba;margin-bottom:18px;letter-spacing:.04em;}
.breadcrumb a:hover{color:var(--brass-light);}
.breadcrumb svg{width:14px;height:14px;}

/* prose */
.prose{max-width:760px;}
.prose h2{margin-top:1.6em;}
.prose h3{margin-top:1.5em;color:var(--navy);}
.prose p{color:var(--ink-soft);font-size:1.12rem;}
.prose .lead{color:var(--ink);font-size:1.32rem;font-family:var(--serif);line-height:1.5;}
.pull{border-left:3px solid var(--brass);padding:6px 0 6px 26px;margin:30px 0;font-family:var(--serif);font-size:1.55rem;line-height:1.42;color:var(--navy);font-style:italic;}

.split-story{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.story-figure{position:sticky;top:110px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);}
.story-figure img{width:100%;height:100%;object-fit:cover;min-height:520px;}
.factlist{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:2px;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;}
.factlist li{display:flex;gap:16px;align-items:center;padding:18px 22px;background:var(--paper);}
.factlist li svg{width:22px;height:22px;color:var(--brass-deep);flex:0 0 auto;}
.factlist b{color:var(--navy);}
.factlist span{color:var(--muted);font-size:.96rem;display:block;}

/* practice detail cards (ypiresies) */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
.svc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px 32px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--brass-light);}
.svc-card .idx{font-family:var(--serif);font-size:1rem;font-weight:600;letter-spacing:.16em;color:var(--brass-deep);}
.svc-card h3{margin:.5em 0 .4em;color:var(--navy);}
.svc-card p{color:var(--muted);font-size:1.01rem;margin:0 0 1em;}
.svc-card ul{list-style:none;margin:0;padding:0;display:grid;gap:9px;}
.svc-card li{display:flex;gap:11px;align-items:flex-start;color:var(--ink-soft);font-size:.96rem;}
.svc-card li svg{width:17px;height:17px;color:var(--brass);flex:0 0 auto;margin-top:5px;}

.note-box{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--brass);border-radius:12px;padding:22px 26px;color:var(--ink-soft);}
.note-box b{color:var(--navy);}

/* faq */
.faq{max-width:820px;margin:0 auto;}
.qa{border-bottom:1px solid var(--line);}
.qa summary{cursor:pointer;list-style:none;padding:24px 4px;display:flex;justify-content:space-between;gap:20px;align-items:center;font-family:var(--serif);font-size:1.3rem;color:var(--navy);font-weight:600;}
.qa summary::-webkit-details-marker{display:none;}
.qa summary .ic{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:all .25s;color:var(--brass-deep);}
.qa summary .ic svg{width:16px;height:16px;transition:transform .25s;}
.qa[open] summary .ic{background:var(--navy);border-color:var(--navy);color:var(--brass-light);}
.qa[open] summary .ic svg{transform:rotate(45deg);}
.qa .ans{padding:0 4px 26px;color:var(--muted);font-size:1.05rem;}

/* =====================================================================
   CONTACT PAGE
   ===================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start;}
.contact-cards{display:grid;gap:16px;}
.cc{display:flex;gap:18px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px 24px;box-shadow:var(--shadow-sm);}
.cc .ico{width:46px;height:46px;border-radius:11px;background:var(--ivory);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--brass-deep);}
.cc .ico svg{width:22px;height:22px;}
.cc b{display:block;color:var(--navy);font-weight:600;margin-bottom:2px;}
.cc a,.cc span{color:var(--muted);}
.cc a:hover{color:var(--brass-deep);}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow);}
.map-wide{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#dfe6ee;}
.map-wide iframe{width:100%;height:420px;border:0;display:block;}

.field{margin-bottom:18px;}
.field label{display:block;font-size:.86rem;font-weight:600;color:var(--navy);margin-bottom:7px;letter-spacing:.02em;}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--ivory-2);
  border:1.5px solid var(--line);border-radius:10px;padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.field textarea{resize:vertical;min-height:110px;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(176,141,76,.16);background:#fff;}
.field .hint{font-size:.82rem;color:var(--muted-2);margin-top:6px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.demo-badge{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--muted);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:13px 15px;margin:6px 0 18px;}
.demo-badge svg{width:18px;height:18px;color:var(--brass-deep);flex:0 0 auto;margin-top:1px;}
.form-ok{display:none;text-align:center;padding:20px 0;}
.form-ok.show{display:block;}
.form-ok .check{width:62px;height:62px;border-radius:50%;background:rgba(176,141,76,.14);color:var(--brass-deep);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.form-ok .check svg{width:30px;height:30px;}

.hours-table{list-style:none;margin:0;padding:0;}
.hours-table li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:1rem;}
.hours-table li:last-child{border-bottom:0;}
.hours-table .d{color:var(--ink);font-weight:500;}
.hours-table .h{color:var(--muted);}
.hours-table li.closed .h{color:var(--oxblood);}
.hours-table li.today{background:rgba(176,141,76,.08);margin:0 -12px;padding-left:12px;padding-right:12px;border-radius:8px;}

/* =====================================================================
   BOOKING (rantevou)
   ===================================================================== */
.booking-wrap{max-width:1080px;margin:0 auto;}
.booking-shell{display:grid;grid-template-columns:300px 1fr;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;}
.booking-aside{background:var(--navy);color:#dce3ef;padding:34px 28px;}
.ba-brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.4rem;font-weight:600;color:#fff;margin-bottom:26px;}
.ba-brand img{width:42px;height:42px;}
.ba-line{display:flex;gap:13px;align-items:flex-start;margin-bottom:20px;font-size:.92rem;color:#b6c0d4;}
.ba-line svg{width:20px;height:20px;color:var(--brass-light);flex:0 0 auto;margin-top:2px;}
.ba-line strong{display:block;color:#fff;font-weight:600;margin-bottom:2px;}
.ba-summary{margin-top:26px;border-top:1px solid var(--line-navy);padding-top:20px;}
.ba-summary .row{display:flex;justify-content:space-between;gap:14px;padding:7px 0;font-size:.92rem;}
.ba-summary .row span{color:#93a0ba;}
.ba-summary .row b{color:#fff;font-weight:600;text-align:right;}
.ba-sel{margin-top:24px;font-size:.78rem;line-height:1.55;color:#93a0ba;background:rgba(255,255,255,.05);border-radius:10px;padding:13px 15px;}

.booking-main{padding:34px 36px 40px;}
.steps-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px;}
.pill{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--muted);background:var(--ivory);border:1px solid var(--line);border-radius:10px;padding:7px 14px;}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--line);}
.pill.active{color:var(--navy);border-color:var(--brass-light);background:#fff;}
.pill.active .dot{background:var(--brass);}
.pill.done{color:var(--brass-deep);}
.pill.done .dot{background:var(--brass);}
.bk-step{display:none;animation:fade .35s var(--ease);}
.bk-step.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.bk-step h2{font-size:1.7rem;margin-bottom:.3em;}
.bk-step .sub{color:var(--muted);margin-bottom:22px;}

.svc-list{display:grid;gap:12px;}
.svc{display:flex;align-items:center;gap:18px;width:100%;text-align:left;background:var(--ivory-2);border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s,background .2s;font-family:inherit;}
.svc:hover{border-color:var(--brass-light);transform:translateY(-2px);box-shadow:var(--shadow-sm);background:#fff;}
.svc.sel{border-color:var(--brass);background:#fff;box-shadow:0 0 0 3px rgba(176,141,76,.14);}
.svc .chip{width:46px;height:46px;border-radius:11px;background:var(--navy);color:var(--brass-light);font-family:var(--serif);font-weight:600;font-size:1.15rem;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.svc .meta{flex:1;display:flex;flex-direction:column;}
.svc .meta b{color:var(--navy);font-size:1.05rem;font-weight:600;}
.svc .meta span{color:var(--muted);font-size:.88rem;}
.svc .pr{text-align:right;color:var(--brass-deep);font-weight:600;font-size:.95rem;white-space:nowrap;}
.svc .pr .d{display:block;color:var(--muted-2);font-weight:500;font-size:.78rem;}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-head .mname{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--navy);}
.cal-nav{display:flex;gap:8px;}
.cal-nav button{width:40px;height:40px;border-radius:10px;border:1.5px solid var(--line);background:#fff;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.cal-nav button:hover:not(:disabled){border-color:var(--brass);color:var(--brass-deep);}
.cal-nav button:disabled{opacity:.35;cursor:not-allowed;}
.cal-nav svg{width:18px;height:18px;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-grid .dow{text-align:center;font-size:.74rem;font-weight:600;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;padding:6px 0;}
.cal-day{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:11px;font-size:.98rem;color:var(--muted-2);border:1.5px solid transparent;}
.cal-day.empty{visibility:hidden;}
.cal-day.off{color:#c3bba8;text-decoration:none;}
.cal-day.off::after{content:"";position:absolute;width:18px;height:1px;background:#ded5c2;transform:rotate(-18deg);}
.cal-day.free{cursor:pointer;color:var(--navy);font-weight:600;background:rgba(176,141,76,.1);border-color:rgba(176,141,76,.28);transition:all .18s;}
.cal-day.free:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px);}
.cal-day.free .ndots{display:flex;gap:2px;margin-top:3px;}
.cal-day.free .ndots i{width:4px;height:4px;border-radius:50%;background:var(--brass);}
.cal-day.free:hover .ndots i{background:var(--brass-light);}
.cal-day.sel{background:var(--navy);color:#fff;border-color:var(--navy);}
.cal-day.sel .ndots i{background:var(--brass-light);}
.cal-legend{display:flex;flex-wrap:wrap;gap:18px;margin-top:18px;font-size:.82rem;color:var(--muted);}
.cal-legend span{display:inline-flex;align-items:center;gap:7px;}
.cal-legend i{width:14px;height:14px;border-radius:4px;display:inline-block;}
.cal-legend .l-free{background:rgba(176,141,76,.18);border:1.5px solid rgba(176,141,76,.4);}
.cal-legend .l-sel{background:var(--navy);}
.cal-legend .l-off{background:#ece6d8;}

.slot-head{display:flex;gap:14px;align-items:center;margin-bottom:20px;}
.slot-head .back{width:40px;height:40px;border-radius:10px;border:1.5px solid var(--line);background:#fff;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.slot-head .back:hover{border-color:var(--brass);color:var(--brass-deep);}
.slot-head .back svg{width:18px;height:18px;}
.slot-head .dsel{font-size:.92rem;color:var(--muted);}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;}
.slot{padding:13px 8px;border-radius:10px;border:1.5px solid var(--line);background:var(--ivory-2);color:var(--navy);font-weight:600;font-size:.98rem;cursor:pointer;transition:all .18s;font-family:inherit;}
.slot:hover{border-color:var(--brass);background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.slot.sel{background:var(--navy);color:#fff;border-color:var(--navy);}
.slots-empty{padding:26px;text-align:center;color:var(--muted);background:var(--ivory-2);border:1px dashed var(--line);border-radius:12px;}
.form-actions{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;}

.confirm{text-align:center;max-width:520px;margin:0 auto;padding:10px 0;}
.confirm .check{width:74px;height:74px;border-radius:50%;background:rgba(176,141,76,.15);color:var(--brass-deep);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.confirm .check svg{width:36px;height:36px;}
.recap{text-align:left;background:var(--ivory-2);border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin:24px 0;}
.recap .row{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--line);}
.recap .row:last-child{border-bottom:0;}
.recap .row span{color:var(--muted);}
.recap .row b{color:var(--navy);text-align:right;}
.note{font-size:.84rem;color:var(--muted-2);line-height:1.6;}

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{background:var(--navy-deep);color:#aab4c8;padding:72px 0 30px;position:relative;}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--brass),transparent);}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.3fr;gap:48px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand{display:flex;align-items:center;gap:13px;margin-bottom:18px;}
.footer-brand img{width:48px;height:48px;}
.footer-brand .bt b{font-family:var(--serif);font-size:1.35rem;color:#fff;font-weight:600;display:block;line-height:1.05;}
.footer-brand .bt small{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-light);}
.site-footer p{color:#93a0ba;font-size:.96rem;max-width:330px;}
.footer-col h4{font-family:var(--sans);font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-light);margin:0 0 18px;}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;}
.footer-col ul a{color:#aeb8cc;font-size:.96rem;transition:color .2s;}
.footer-col ul a:hover{color:#fff;}
.footer-col .row{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;font-size:.95rem;color:#aeb8cc;}
.footer-col .row svg{width:18px;height:18px;color:var(--brass-light);flex:0 0 auto;margin-top:3px;}
.footer-col .row a{color:#aeb8cc;}
.footer-col .row a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:.84rem;color:#76819a;}
.footer-bottom a{color:#9aa5bb;}
.footer-bottom a:hover{color:var(--brass-light);}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:40px;padding-top:64px;padding-bottom:64px;}
  .hero-figure{max-width:560px;}
  .hero-figure .frame img{height:420px;}
  .intro,.feature,.feature--reverse,.mapblock,.contact-grid,.split-story{grid-template-columns:1fr;gap:36px;}
  .feature--reverse .feature-fig{order:0;}
  .story-figure{position:static;}
  .story-figure img{min-height:340px;}
  .values,.values--4{grid-template-columns:1fr 1fr;}
  .steps{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
}
@media (max-width:760px){
  body{font-size:16px;}
  .section{padding:68px 0;}
  .topbar .tb-left{display:none;}
  .topbar .container{justify-content:center;}
  .nav-cta .btn--ghost{display:none;}
  .nav-toggle{display:flex;}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:4px;
    background:var(--ivory-2);border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    padding:14px 20px 20px;display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links a:not(.btn){padding:12px 8px;border-radius:8px;width:100%;}
  .nav-links a:not(.btn)::after{display:none;}
  .nav-links a:not(.btn).active{background:rgba(176,141,76,.1);}
  .nav-links .btn{margin:8px 0 0;width:100%;}
  .booking-shell{grid-template-columns:1fr;}
  .booking-aside{order:2;}
  .booking-main{padding:26px 20px 30px;}
  .values,.values--4{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:30px;padding-bottom:34px;}
  .form-row{grid-template-columns:1fr;}
  .area{grid-template-columns:54px 1fr;gap:16px;}
  .area .go{display:none;}
  .hero-figure .tag{left:12px;right:12px;max-width:none;}
  .hero-figure .frame img{height:360px;}
  .cta-band .container{padding:64px 24px;}
}
@media (max-width:420px){
  .brand .bt small{display:none;}
  .hero-actions .btn{width:100%;}
}
