/* ===========================================================
   Τεχνικό Γραφείο Χασάπης Κωνσταντίνος — shared design system
   "Cadastre precision": deep navy ink on warm concrete paper,
   surveyor-amber accent, blueprint-grid hairlines.
   Archivo (display) · IBM Plex Sans (body) · IBM Plex Mono (labels)
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  --ink:#0E2233;
  --ink-2:#16344C;
  --navy:#12283A;
  --paper:#F3EFE6;
  --paper-2:#EAE4D6;
  --surface:#FBF9F3;
  --surface-2:#FFFFFF;
  --line:#D9D1C0;
  --line-strong:#C7BCA5;
  --text:#1B2A33;
  --muted:#5A6770;
  --muted-light:#9DB0BD;          /* muted text on dark */
  --amber:#B45F1C;                /* accent for LIGHT backgrounds (passes contrast) */
  --amber-2:#C9772E;
  --amber-bright:#E6A24C;         /* accent for DARK backgrounds */
  --steel:#5C7080;
  --radius:14px;
  --radius-sm:11px;
  --radius-lg:20px;
  --shadow:0 26px 50px -30px rgba(10,28,44,.55);
  --shadow-soft:0 16px 36px -24px rgba(10,28,44,.40);
  --maxw:1180px;
  --disp:'Archivo',Georgia,sans-serif;
  --sans:'IBM Plex Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --grid-light:rgba(18,40,58,.045);
  --grid-dark:rgba(173,200,220,.07);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:var(--paper);
  line-height:1.68;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* faint blueprint grid over the whole canvas */
  background-image:
    linear-gradient(var(--grid-light) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-light) 1px,transparent 1px);
  background-size:30px 30px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.08;margin:0 0 .45em;color:var(--ink);letter-spacing:-.015em}
h1{font-size:clamp(2.5rem,6vw,4.3rem)}
h2{font-size:clamp(2rem,4.2vw,3.1rem)}
h3{font-size:1.42rem}
h4{font-size:1.08rem}
p{margin:0 0 1.1rem}
strong{font-weight:600}

.container{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.section{padding:104px 0;position:relative}
.section--tight{padding:72px 0}
.center{text-align:center}
.lead{font-size:1.18rem;color:var(--muted);max-width:64ch}
.center .lead{margin-left:auto;margin-right:auto}
.measure{max-width:66ch}

/* ---------- mono micro-labels ---------- */
.tag{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.72rem;
  font-weight:500;
  color:var(--amber);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin:0 0 1.1rem;
}
.tag::before{content:"";width:18px;height:1px;background:currentColor;opacity:.8}
.tag--plain::before{display:none}
.section--dark .tag{color:var(--amber-bright)}

.idx{font-family:var(--mono);font-size:.74rem;color:var(--amber);letter-spacing:.1em;font-weight:500}
.section--dark .idx{color:var(--amber-bright)}

/* ---------- buttons (one size system, calm radius) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:.97rem;
  letter-spacing:.01em;line-height:1;
  padding:.92em 1.55em;border-radius:var(--radius-sm);
  border:1.5px solid transparent;cursor:pointer;
  transition:transform .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease,border-color .22s ease;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;flex:none}
.btn--accent{background:linear-gradient(135deg,#D98A37,#B45F1C);color:#fff;box-shadow:var(--shadow-soft)}
.btn--accent:hover{transform:translateY(-2px);box-shadow:0 20px 34px -20px rgba(180,95,28,.7)}
.btn--primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--primary:hover{background:#0a1a28;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn--ghost:hover{border-color:var(--ink);background:rgba(14,34,51,.04)}
.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)}
.btn--light{background:var(--surface-2);color:var(--ink);border-color:var(--surface-2)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--block{width:100%}
.btn--sm{padding:.66em 1.05em;font-size:.86rem}
.btn--lg{padding:1.05em 2em;font-size:1.04rem}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(243,239,230,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:13px 26px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:.62em;font-family:var(--disp);font-size:1.12rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.brand img{width:34px;height:34px}
.brand small{display:block;font-family:var(--mono);font-size:.6rem;font-weight:400;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;margin-top:1px}
.brand .brand-txt{line-height:1.05}

.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a:not(.btn){
  font-family:var(--sans);font-weight:500;font-size:.96rem;color:var(--text);
  position:relative;padding:4px 0;transition:color .2s ease;
}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;
  background:var(--amber);transition:width .25s ease;
}
.nav-links a:not(.btn):hover{color:var(--ink)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-links a:not(.btn).active{color:var(--ink)}
.nav-links a:not(.btn).active::after{width:100%}

.nav-cta{display:flex;align-items:center;gap:10px}
.nav-cta-mobile{display:none}
.nav-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:10px;padding:8px;cursor:pointer;color:var(--ink)}
.nav-toggle svg{width:22px;height:22px;display:block}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:74px 0 96px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin-bottom:.3em}
.hero .lead{margin-bottom:1.9rem}
.hero-ccoord{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.08em;margin-bottom:1.4rem;display:flex;flex-wrap:wrap;gap:.5em 1.1em}
.hero-ccoord span{display:inline-flex;align-items:center;gap:.45em}
.hero-ccoord b{color:var(--amber);font-weight:600}
.hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:.5rem}
.hero-trust{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:8px 22px;font-family:var(--mono);font-size:.74rem;color:var(--muted);letter-spacing:.04em}
.hero-trust span{display:inline-flex;align-items:center;gap:.5em}
.hero-trust svg{width:15px;height:15px;color:var(--amber)}

/* framed hero image with registration ticks */
.framed{position:relative;border-radius:var(--radius-lg);padding:12px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow)}
.framed::before,.framed::after{content:"";position:absolute;width:16px;height:16px;border:2px solid var(--amber);z-index:2}
.framed::before{top:-2px;left:-2px;border-right:0;border-bottom:0;border-top-left-radius:6px}
.framed::after{bottom:-2px;right:-2px;border-left:0;border-top:0;border-bottom-right-radius:6px}
.framed .frame-img{border-radius:12px;overflow:hidden;background:var(--paper-2);position:relative}
.framed .frame-img img{width:100%;height:clamp(340px,46vw,500px);object-fit:cover}
.frame-cap{display:flex;justify-content:space-between;align-items:center;gap:10px;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;color:var(--muted);padding:10px 6px 4px;text-transform:uppercase}
.frame-cap b{color:var(--ink);font-weight:600}

/* ---------- sections / surfaces ---------- */
.section--paper2{background:var(--paper-2)}
.section--surface{background:var(--surface)}
.section--dark{background:var(--ink);color:#E7EEF3;position:relative}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark .lead{color:var(--muted-light)}
.section--dark::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(var(--grid-dark) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);
  background-size:32px 32px;opacity:.8;
}
.section--dark .container{position:relative;z-index:1}

.sec-head{max-width:60ch}
.sec-head.center{margin:0 auto}
.sec-head h2{margin-bottom:.35em}

/* ---------- trust strip ---------- */
.trust-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface)}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust-cell{padding:30px 26px;border-right:1px solid var(--line)}
.trust-cell:last-child{border-right:0}
.trust-cell .idx{display:block;margin-bottom:.7rem}
.trust-cell h4{margin:0 0 .25em;font-size:1.04rem;color:var(--ink)}
.trust-cell p{margin:0;font-size:.92rem;color:var(--muted);line-height:1.5}

/* ---------- service cards ---------- */
.cards{display:grid;gap:22px}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.card-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--paper-2)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-img img{transform:scale(1.05)}
.card-num{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:.7rem;font-weight:600;
  background:#0E2233;color:#fff;padding:4px 9px;border-radius:7px;letter-spacing:.08em;box-shadow:0 4px 12px -4px rgba(0,0,0,.5)}
.card-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.22rem;margin-bottom:.4em}
.card-body p{font-size:.95rem;color:var(--muted);margin-bottom:1.1rem}
.card-link{margin-top:auto;font-family:var(--mono);font-size:.78rem;font-weight:600;letter-spacing:.06em;
  color:var(--amber);text-transform:uppercase;display:inline-flex;align-items:center;gap:.5em}
.card-link svg{width:15px;height:15px;transition:transform .25s ease}
.card:hover .card-link svg{transform:translateX(4px)}

/* compact list version (services page extras) */
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:8px}
.svc-item{display:flex;gap:16px;padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.svc-item .svc-ic{flex:none;width:44px;height:44px;border-radius:11px;background:rgba(180,95,28,.10);
  display:grid;place-items:center;color:var(--amber)}
.svc-item .svc-ic svg{width:21px;height:21px}
.svc-item h4{margin:0 0 .3em;font-size:1.06rem;color:var(--ink)}
.svc-item p{margin:0;font-size:.9rem;color:var(--muted);line-height:1.55}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:18px}
.step{position:relative;padding-top:26px;border-top:2px solid var(--line-strong)}
.step .step-n{font-family:var(--mono);font-size:.78rem;color:var(--amber);font-weight:600;letter-spacing:.1em}
.step h4{margin:.5em 0 .35em;font-size:1.14rem;color:var(--ink)}
.section--dark .step{border-top-color:rgba(173,200,220,.22)}
.section--dark .step h4{color:#fff}
.step p{font-size:.93rem;color:var(--muted);margin:0}
.section--dark .step p{color:var(--muted-light)}
.section--dark .step .step-n{color:var(--amber-bright)}

/* ---------- split / feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split--narrow{gap:46px}
.split-media{position:relative}
.split-media img{width:100%;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-soft);object-fit:cover}
.checklist{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:13px}
.checklist li{display:flex;gap:13px;align-items:flex-start;font-size:1rem}
.checklist svg{flex:none;width:21px;height:21px;color:var(--amber);margin-top:2px}
.section--dark .checklist svg{color:var(--amber-bright)}
.section--dark .checklist li{color:#D7E2EA}

/* stat callouts on dark */
.statline{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.statline .pill{font-family:var(--mono);font-size:.76rem;letter-spacing:.05em;color:#fff;
  border:1px solid rgba(173,200,220,.28);border-radius:9px;padding:9px 14px;background:rgba(255,255,255,.04)}
.statline .pill b{color:var(--amber-bright);font-weight:600}

/* ---------- map band ---------- */
.maprow{display:grid;grid-template-columns:1fr 1.25fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface)}
.map-info{padding:42px}
.map-info h3{margin-bottom:.5em}
.map-frame{min-height:360px;background:var(--paper-2)}
.map-frame iframe{width:100%;height:100%;min-height:360px;border:0;display:block;filter:grayscale(.25) contrast(1.02)}
.infoline{display:flex;gap:13px;align-items:flex-start;margin:0 0 16px;font-size:.97rem}
.infoline svg{flex:none;width:20px;height:20px;color:var(--amber);margin-top:3px}
.infoline b{display:block;color:var(--ink);font-weight:600;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1px}
.infoline span{color:var(--muted)}
.infoline a{color:var(--text)}
.infoline a:hover{color:var(--amber)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;color:#fff;background:var(--ink);overflow:hidden}
.cta-band .cta-bg{position:absolute;inset:0;background-color:#0c1f30;background-size:cover;background-position:center;opacity:.32}
.cta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(12,28,44,.92),rgba(12,28,44,.6))}
.cta-inner{position:relative;z-index:2;padding:88px 0;text-align:center;max-width:62ch;margin:0 auto}
.cta-inner h2{color:#fff}
.cta-inner p{color:#CBD7DF;font-size:1.12rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:1.6rem}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#BFD0DC;position:relative}
.site-footer::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--grid-dark) 1px,transparent 1px),linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);
  background-size:32px 32px;opacity:.6;
}
.footer-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:34px;padding:66px 0 40px}
.footer-brand{display:flex;align-items:center;gap:.6em;font-family:var(--disp);font-weight:700;font-size:1.15rem;color:#fff;margin-bottom:1rem}
.footer-brand img{width:36px;height:36px}
.footer-col h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-bright);margin:0 0 1.1rem;font-weight:500}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer-col a,.footer-col li{font-size:.94rem;color:#AFC2D0}
.footer-col a:hover{color:#fff}
.footer-about p{font-size:.94rem;color:#9DB2C0;max-width:34ch}
.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(173,200,220,.16);padding:20px 0 30px;
  display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:space-between;align-items:center}
.footer-bottom p{margin:0;font-size:.82rem;color:#85A0B2}
.footer-bottom .mono{font-family:var(--mono);letter-spacing:.04em}

/* ---------- misc ---------- */
.note{font-family:var(--mono);font-size:.78rem;color:var(--muted);background:rgba(180,95,28,.07);
  border:1px solid rgba(180,95,28,.22);border-left:3px solid var(--amber);border-radius:9px;padding:13px 16px;line-height:1.55}
.section--dark .note{color:var(--muted-light);background:rgba(230,162,76,.08);border-color:rgba(230,162,76,.3);border-left-color:var(--amber-bright)}
.pin{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--amber);text-transform:uppercase}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* page hero (interior pages) */
.page-hero{padding:72px 0 38px;border-bottom:1px solid var(--line);position:relative}
.page-hero .crumbs{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:1rem}
.page-hero .crumbs a:hover{color:var(--amber)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.5rem);margin-bottom:.3em}
.page-hero .lead{margin-bottom:.4rem}

/* prose */
.prose p{color:var(--text)}
.prose h3{margin-top:1.6em}
.prose .lead{color:var(--muted)}

/* =========================================================
   Booking widget (rantevou.html)
   ========================================================= */
.booking-wrap{display:grid;grid-template-columns:340px 1fr;gap:30px;align-items:start}
.bk-aside{position:sticky;top:92px;background:var(--ink);color:#DCE7EE;border-radius:var(--radius-lg);padding:28px;overflow:hidden}
.bk-aside::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--grid-dark) 1px,transparent 1px),linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);
  background-size:28px 28px;opacity:.7}
.bk-aside>*{position:relative;z-index:1}
.bk-aside .who{display:flex;align-items:center;gap:13px;margin-bottom:20px}
.bk-aside .who img{width:46px;height:46px;border-radius:11px;border:1px solid rgba(255,255,255,.18);object-fit:cover}
.bk-aside .who b{display:block;color:#fff;font-family:var(--disp);font-size:1.04rem}
.bk-aside .who span{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;color:var(--amber-bright);text-transform:uppercase}
.bk-summary{display:grid;gap:1px;background:rgba(173,200,220,.16);border:1px solid rgba(173,200,220,.16);border-radius:12px;overflow:hidden;margin-bottom:18px}
.bk-summary .row{background:var(--ink);padding:13px 15px;display:flex;gap:12px;align-items:flex-start}
.bk-summary .row svg{width:17px;height:17px;color:var(--amber-bright);flex:none;margin-top:2px}
.bk-summary .row .k{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-light);display:block;margin-bottom:2px}
.bk-summary .row .v{font-size:.95rem;color:#fff}
.bk-summary .row .v.empty{color:#7f97a8}
.bk-demo{font-family:var(--mono);font-size:.74rem;line-height:1.6;color:#CBB99B;background:rgba(230,162,76,.1);border:1px solid rgba(230,162,76,.28);border-left:3px solid var(--amber-bright);border-radius:10px;padding:13px 15px}

.bk-main{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;min-height:520px}
.bk-stepbar{display:flex;gap:8px;margin-bottom:26px;flex-wrap:wrap}
.bk-stepbar .st{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:8px;border:1px solid var(--line)}
.bk-stepbar .st b{color:var(--amber);font-weight:600}
.bk-stepbar .st.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.bk-stepbar .st.active b{color:var(--amber-bright)}
.bk-stepbar .st.done{border-color:var(--amber);color:var(--ink)}
.bk-step{display:none}
.bk-step.active{display:block;animation:bkfade .3s ease}
@keyframes bkfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.bk-step h3{margin-bottom:.2em}
.bk-step .sub{color:var(--muted);font-size:.96rem;margin-bottom:1.4rem}

/* service option list */
.svc-opts{display:grid;gap:12px}
.svc-opt{display:flex;align-items:center;gap:16px;width:100%;text-align:left;cursor:pointer;
  background:var(--surface-2);border:1.5px solid var(--line);border-radius:var(--radius);padding:16px 18px;
  transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;font-family:inherit}
.svc-opt:hover{border-color:var(--amber);transform:translateX(3px)}
.svc-opt.sel{border-color:var(--amber);box-shadow:0 0 0 3px rgba(180,95,28,.12)}
.svc-opt .bar{width:4px;align-self:stretch;border-radius:4px;background:var(--amber);opacity:.85;flex:none}
.svc-opt .txt{flex:1}
.svc-opt .txt b{display:block;font-family:var(--disp);font-size:1.08rem;color:var(--ink);font-weight:600}
.svc-opt .txt span{font-size:.88rem;color:var(--muted)}
.svc-opt .dur{font-family:var(--mono);font-size:.74rem;letter-spacing:.05em;color:var(--ink);background:var(--paper-2);
  border-radius:7px;padding:6px 10px;white-space:nowrap}

/* calendar */
.cal-layout{display:grid;grid-template-columns:1fr;gap:22px}
.cal{max-width:430px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-head .mlabel{font-family:var(--disp);font-weight:600;font-size:1.16rem;color:var(--ink);text-transform:capitalize}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);
  cursor:pointer;display:grid;place-items:center;color:var(--ink);transition:all .2s ease}
.cal-nav button:hover:not(:disabled){border-color:var(--ink);background:var(--paper-2)}
.cal-nav button:disabled{opacity:.35;cursor:not-allowed}
.cal-nav button svg{width:18px;height:18px}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{text-align:center;font-family:var(--mono);font-size:.64rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative}
.cal-day{width:100%;height:100%;border-radius:10px;border:1px solid transparent;background:transparent;
  font-family:var(--sans);font-size:.95rem;font-weight:500;color:var(--ink);cursor:pointer;position:relative;
  transition:all .18s ease}
.cal-day.free{background:var(--surface-2);border-color:var(--line-strong)}
.cal-day.free:hover{border-color:var(--amber);background:#fff;transform:translateY(-1px)}
.cal-day.free::after{content:"";position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  width:5px;height:5px;border-radius:50%;background:var(--amber)}
.cal-day.disabled{color:var(--line-strong);cursor:not-allowed;background:transparent}
.cal-day.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.cal-day.sel::after{background:var(--amber-bright)}
.cal-day.today{box-shadow:inset 0 0 0 1.5px var(--steel)}
.cal-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;font-family:var(--mono);font-size:.7rem;color:var(--muted)}
.cal-legend span{display:inline-flex;align-items:center;gap:7px}
.cal-legend i{width:12px;height:12px;border-radius:4px;display:inline-block}
.cal-legend i.free{background:var(--surface-2);border:1px solid var(--line-strong);position:relative}
.cal-legend i.full{background:transparent;border:1px solid var(--line)}

/* slots */
.slots-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.slots-head b{font-family:var(--disp);font-size:1.12rem;color:var(--ink)}
.slots-head span{font-family:var(--mono);font-size:.74rem;color:var(--muted)}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}
.slot{font-family:var(--mono);font-size:.92rem;font-weight:500;padding:13px 8px;border-radius:10px;
  border:1.5px solid var(--line-strong);background:var(--surface-2);color:var(--ink);cursor:pointer;
  transition:all .18s ease}
.slot:hover{border-color:var(--amber);background:#fff;transform:translateY(-1px)}
.slot.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.slots-empty{padding:26px;text-align:center;color:var(--muted);background:var(--paper-2);border-radius:12px;font-size:.95rem}

/* form */
.bk-form{display:grid;gap:16px;max-width:480px}
.bk-field label{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.bk-field input,.bk-field textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--text);
  background:var(--surface-2);border:1.5px solid var(--line-strong);border-radius:11px;padding:12px 14px;transition:border-color .2s ease}
.bk-field input:focus,.bk-field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(180,95,28,.12)}
.bk-field input.invalid{border-color:#c0392b}
.bk-field textarea{resize:vertical;min-height:84px}
.bk-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.bk-back{background:none;border:0;color:var(--muted);font-family:var(--sans);font-weight:600;font-size:.92rem;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;padding:8px 4px}
.bk-back:hover{color:var(--ink)}
.bk-back svg{width:16px;height:16px}

/* confirmation */
.bk-confirm{text-align:center;padding:20px 10px 8px;max-width:520px;margin:0 auto}
.bk-confirm .seal{width:74px;height:74px;border-radius:50%;background:rgba(180,95,28,.12);display:grid;place-items:center;margin:0 auto 20px}
.bk-confirm .seal svg{width:36px;height:36px;color:var(--amber);stroke-width:2.4}
.bk-confirm h3{font-size:1.7rem}
.bk-confirm p{color:var(--muted)}
.bk-recap{text-align:left;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:20px 22px;margin:22px 0;display:grid;gap:12px}
.bk-recap .row{display:flex;gap:12px;align-items:flex-start}
.bk-recap .row svg{width:18px;height:18px;color:var(--amber);flex:none;margin-top:2px}
.bk-recap .row .k{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block}
.bk-recap .row .v{color:var(--ink);font-weight:500}
.bk-confirm .cf-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

@media (max-width:880px){
  .booking-wrap{grid-template-columns:1fr}
  .bk-aside{position:static}
}
@media (max-width:560px){
  .bk-main{padding:22px 18px}
  .slots{grid-template-columns:repeat(auto-fill,minmax(82px,1fr))}
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:-1}
  .split,.split--narrow{grid-template-columns:1fr;gap:34px}
  .maprow{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .steps{grid-template-columns:repeat(2,1fr);gap:28px}
  .trust-row{grid-template-columns:1fr 1fr}
  .trust-cell:nth-child(2){border-right:0}
  .trust-cell:nth-child(1),.trust-cell:nth-child(2){border-bottom:1px solid var(--line)}
}
@media (max-width:760px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--surface);border-bottom:1px solid var(--line);
    padding:14px 26px 22px;display:none;box-shadow:var(--shadow-soft);
  }
  .nav-links.open{display:flex}
  .nav-links a:not(.btn){width:100%;padding:11px 0;border-bottom:1px solid var(--line);font-size:1rem}
  .nav-links a:not(.btn)::after{display:none}
  .nav-links .nav-cta-mobile{display:flex;gap:10px;width:100%;margin-top:12px}
  .nav-links .nav-cta-mobile .btn{flex:1}
  .nav .nav-cta{display:none}
  .section{padding:78px 0}
  .cards--3,.cards--2,.svc-list{grid-template-columns:1fr}
  .cta-inner{padding:70px 0}
}
@media (max-width:560px){
  body{font-size:16px}
  .container{padding:0 20px}
  .steps,.trust-row{grid-template-columns:1fr}
  .trust-cell{border-right:0;border-bottom:1px solid var(--line)}
  .trust-cell:last-child{border-bottom:0}
  .footer-grid{grid-template-columns:1fr}
  .map-info{padding:30px}
  .framed .frame-img img{height:300px}
  .hero-actions .btn{flex:1}
}
