/* ============================================
   DABBLE SERVICES — Clean Business Site
   Supports dark (default) and light themes
   ============================================ */

:root{
  /* DARK THEME (default) */
  --bg: #0e1014;
  --bg-2: #161920;
  --surface: #1a1e26;
  --ink: #f5f6f8;
  --ink-2: #d4d7de;
  --muted: #8d93a1;
  --muted-2: #5a6070;
  --line: rgba(180,188,204,0.10);
  --line-2: rgba(180,188,204,0.18);
  --brand: #2e5cc9;          /* Logo royal blue */
  --brand-2: #5bb8ea;         /* Logo cyan */
  --brand-ink: #ffffff;       /* Text on brand colour */
  --success: #6fb894;
}

.theme-light{
  --bg: #ffffff;
  --bg-2: #f6f7f9;
  --surface: #ffffff;
  --ink: #14161b;
  --ink-2: #3a3f4a;
  --muted: #6b7380;
  --muted-2: #a1a8b5;
  --line: rgba(20,22,27,0.08);
  --line-2: rgba(20,22,27,0.14);
  --brand: #2e5cc9;
  --brand-2: #0e78b5;
  --brand-ink: #ffffff;
  --success: #3a9268;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background: var(--bg);
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 32px}

/* ===== LOGO WORDMARK ===== */
.logo-mark{
  display:inline-flex;align-items:center;gap:1px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:24px;letter-spacing:-0.02em;line-height:1;
  color:var(--ink);
}
.logo-mark .bracket{color:var(--muted);font-family:'JetBrains Mono',monospace;font-weight:500;font-size:27px;margin-right:1px}
.logo-mark .slash{color:var(--brand-2);font-family:'JetBrains Mono',monospace;font-weight:500;font-size:27px;margin-left:1px}
.logo-mark:hover .bracket{color:var(--ink-2)}

/* ===== NAV ===== */
header.nav{
  position:sticky;top:0;z-index:40;
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
header.nav .container{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:48px;padding-top:20px;padding-bottom:20px}
nav ul{display:flex;gap:32px;list-style:none;justify-content:center}
nav a{
  font-size:15px;color:var(--muted);
  transition:color 0.2s;
  font-weight:500;
}
nav a:hover{color:var(--ink)}
nav a.active{color:var(--ink)}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;border-radius:8px;
  font-size:14px;font-weight:500;
  transition:all 0.2s;cursor:pointer;border:none;
  font-family:inherit;
}
.btn-primary{background:var(--brand);color:var(--brand-ink)}
.btn-primary:hover{background:var(--brand-2);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn-secondary:hover{border-color:var(--ink);background:var(--bg-2)}
.btn-large{padding:16px 28px;font-size:15px;border-radius:10px}
.btn .arrow{transition:transform 0.2s}
.btn:hover .arrow{transform:translateX(3px)}

/* ===== PAGE HEAD ===== */
.page-head{
  padding: 100px 0 72px;
  border-bottom: 1px solid var(--line);
}
.page-head .eyebrow{
  font-size:13px;color:var(--brand-2);font-weight:500;
  letter-spacing:0.02em;margin-bottom:20px;
}
.page-head h1{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size:clamp(44px,6vw,80px);
  line-height:1.02;letter-spacing:-0.03em;
  color:var(--ink);
  max-width:18ch;
}
.page-head .lede{
  margin-top:28px;font-size:19px;line-height:1.55;
  color:var(--ink-2);max-width:640px;
}
.page-head .lede strong{color:var(--ink);font-weight:500}

/* ===== SECTIONS ===== */
section{padding:100px 0;border-bottom:1px solid var(--line)}

.section-head{
  max-width:800px;margin-bottom:64px;
}
.section-head.centered{text-align:center;margin-left:auto;margin-right:auto}
.section-head .eyebrow{
  font-size:13px;color:var(--brand-2);font-weight:500;
  letter-spacing:0.02em;margin-bottom:16px;
}
.section-head h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size:clamp(36px,4.5vw,56px);
  line-height:1.05;letter-spacing:-0.025em;
  color:var(--ink);
}
.section-head p{
  margin-top:20px;font-size:18px;line-height:1.6;
  color:var(--ink-2);
}

/* ===== METRICS ROW ===== */
.metrics{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.metric{
  padding:40px 32px;
  border-right:1px solid var(--line);
}
.metric:last-child{border-right:none}
.metric .label{
  font-size:13px;color:var(--muted);
  margin-bottom:12px;font-weight:500;
}
.metric .value{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size:44px;line-height:1;letter-spacing:-0.025em;
  color:var(--ink);
}
.metric .unit{font-size:18px;color:var(--muted);font-weight:400;margin-left:2px}
.metric .note{margin-top:12px;font-size:13px;color:var(--muted)}

/* ===== CTA BLOCK ===== */
.cta-block{
  padding:120px 0;text-align:center;
  border-bottom:1px solid var(--line);
}
.cta-block h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size:clamp(40px,5.5vw,72px);
  line-height:1.02;letter-spacing:-0.03em;
  max-width:900px;margin:0 auto 20px;
  color:var(--ink);
}
.cta-block p{
  max-width:600px;margin:0 auto 40px;
  font-size:18px;line-height:1.55;color:var(--ink-2);
}

/* ===== TESTIMONIAL ===== */
.testimonial{padding:120px 0;border-bottom:1px solid var(--line);text-align:center}
.testimonial blockquote{
  font-family:'Space Grotesk',sans-serif;font-weight:400;
  font-size:clamp(24px,3vw,38px);line-height:1.3;letter-spacing:-0.015em;
  color:var(--ink);
  max-width:900px;margin:0 auto 40px;
}
.testimonial .attrib{
  display:inline-flex;align-items:center;gap:16px;
  padding-top:24px;border-top:1px solid var(--line-2);
}
.testimonial .attrib strong{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:18px;color:var(--ink);display:block;letter-spacing:-0.01em;
}
.testimonial .attrib span{font-size:14px;color:var(--muted)}

/* ===== CARDS ===== */
.card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:12px;
  padding:32px;
  transition:all 0.25s;
}
.card:hover{border-color:var(--line-2);transform:translateY(-2px)}
.card h3{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:22px;letter-spacing:-0.015em;margin-bottom:12px;color:var(--ink);
}
.card p{font-size:15px;line-height:1.6;color:var(--ink-2)}

/* ===== PRICING CARDS ===== */
.price-grid{display:grid;gap:20px}
.price-grid.cols-2{grid-template-columns:1fr 1fr}
.price-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.price-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:14px;
  padding:36px 32px;
  position:relative;
  display:flex;flex-direction:column;
}
.price-card h4{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:20px;letter-spacing:-0.01em;margin-bottom:4px;color:var(--ink);
}
.price-card .label{font-size:13px;color:var(--muted);margin-bottom:28px}
.price-card .amount{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:48px;line-height:1;letter-spacing:-0.03em;color:var(--ink);
}
.price-card .amount .cur{font-size:24px;vertical-align:top;color:var(--muted);margin-right:2px}
.price-card .amount .unit{font-size:14px;color:var(--muted);font-weight:400;margin-left:4px}
.price-card .desc{
  margin:16px 0 28px;font-size:15px;line-height:1.55;color:var(--ink-2);
}
.price-card ul{list-style:none;margin-bottom:32px;flex-grow:1}
.price-card li{
  padding:10px 0;font-size:15px;color:var(--ink-2);
  display:flex;gap:12px;align-items:baseline;
  border-bottom:1px solid var(--line);
}
.price-card li:last-child{border-bottom:none}
.price-card li::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--brand-2);flex-shrink:0;transform:translateY(7px);
}
.price-card .btn{width:100%;justify-content:center}
.price-card.featured{
  border-color:var(--brand);
  background:linear-gradient(180deg,color-mix(in srgb,var(--brand) 8%,var(--bg-2)),var(--bg-2));
}
.price-card.featured::before{
  content:"Recommended";
  position:absolute;top:-11px;left:24px;
  background:var(--brand);color:var(--brand-ink);
  padding:4px 12px;border-radius:100px;
  font-size:11px;font-weight:500;letter-spacing:0.02em;
}

/* ===== FOOTER ===== */
footer.site-footer{
  padding:80px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;
  padding-bottom:60px;border-bottom:1px solid var(--line);
}
.footer-grid .brand-block p{
  margin-top:20px;font-size:15px;color:var(--muted);line-height:1.6;max-width:340px;
}
footer h5{
  font-size:13px;color:var(--muted);font-weight:500;margin-bottom:20px;
  letter-spacing:0.02em;
}
footer ul{list-style:none}
footer li{margin-bottom:10px;font-size:15px}
footer li a{color:var(--ink-2);transition:color 0.2s}
footer li a:hover{color:var(--brand-2)}
.footer-bottom{
  padding-top:28px;display:flex;justify-content:space-between;
  font-size:14px;color:var(--muted);
}

/* ===== THEME TOGGLE ===== */
.theme-toggle{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 12px;border:1px solid var(--line-2);border-radius:100px;
  font-size:13px;color:var(--muted);cursor:pointer;
  background:transparent;font-family:inherit;transition:all 0.2s;
}
.theme-toggle:hover{color:var(--ink);border-color:var(--ink)}

/* ===== MOBILE MENU (hamburger + drawer) ===== */
.menu-toggle{
  display:none;
  width:44px;height:44px;
  border:1px solid var(--line-2);border-radius:100px;
  background:transparent;cursor:pointer;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  transition:border-color 0.2s;
  -webkit-tap-highlight-color:transparent;
}
.menu-toggle:hover{border-color:var(--ink)}
.menu-toggle span{
  display:block;width:18px;height:1.5px;
  background:var(--ink);border-radius:2px;
  transition:transform 0.25s ease,opacity 0.2s;
  transform-origin:center;
}
.menu-toggle.is-open{border-color:var(--ink)}
.menu-toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-toggle.is-open span:nth-child(2){opacity:0}
.menu-toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-drawer{display:none}

body.menu-open{overflow:hidden}

@media(max-width:960px){
  .menu-toggle{display:inline-flex}
  /* Hide desktop header items — drawer hosts them on mobile */
  header.nav .theme-toggle,
  header.nav .btn-primary{display:none}

  .mobile-drawer{
    display:flex;flex-direction:column;
    position:fixed;inset:0;z-index:30;
    padding:84px 24px 32px;
    background:var(--bg);
    transform:translateY(-100%);
    transition:transform 0.3s ease;
    overflow-y:auto;
    visibility:hidden;
    -webkit-overflow-scrolling:touch;
  }
  .mobile-drawer.is-open{transform:translateY(0);visibility:visible}
  .mobile-drawer ul{
    list-style:none;display:flex;flex-direction:column;
    border-top:1px solid var(--line);
  }
  .mobile-drawer li{border-bottom:1px solid var(--line)}
  .mobile-drawer li a{
    display:flex;align-items:center;justify-content:space-between;
    padding:22px 4px;
    font-family:'Space Grotesk',sans-serif;font-weight:500;
    font-size:22px;letter-spacing:-0.015em;
    color:var(--ink);
    -webkit-tap-highlight-color:transparent;
  }
  .mobile-drawer li a::after{
    content:"→";color:var(--muted);font-weight:400;font-size:18px;
    transition:transform 0.2s,color 0.2s;
  }
  .mobile-drawer li a:active{color:var(--brand-2)}
  .mobile-drawer li a:active::after{transform:translateX(3px);color:var(--brand-2)}
  .mobile-drawer li a.active{color:var(--brand-2)}
  .mobile-drawer li a.active::after{color:var(--brand-2)}
  .mobile-drawer-foot{
    margin-top:auto;padding-top:32px;
    display:flex;flex-direction:column;gap:14px;
  }
  .mobile-drawer-foot .theme-toggle{
    align-self:flex-start;padding:10px 16px;font-size:14px;
  }
  .mobile-drawer-foot .btn{justify-content:center;padding:16px 20px;font-size:15px}
}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .container{padding:0 24px}
  header.nav .container{grid-template-columns:auto auto;gap:16px}
  nav{display:none}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .metric:nth-child(2){border-right:none}
  .metric:nth-child(1),.metric:nth-child(2){border-bottom:1px solid var(--line)}
  .price-grid.cols-2,.price-grid.cols-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  section,.cta-block,.testimonial{padding:72px 0}
  .page-head{padding:64px 0 56px}
}

/* ============================================
   IMAGERY & MEDIA
   ============================================ */

/* Hero image split layout */
section.hero-split-wrapper{padding:0}
.hero-split{
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
  padding:48px 0 96px;
}
.hero-split.reverse{grid-template-columns:1fr 1.1fr}
.hero-split.reverse .hero-split-media{order:-1}
.hero-split-copy h1{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(44px,5.5vw,80px);line-height:1.02;letter-spacing:-0.035em;
  color:var(--ink);margin-bottom:28px;
}
.hero-split-copy h1 em{font-style:normal;color:var(--brand-2);font-weight:500}
.hero-split-copy .eyebrow{font-size:13px;color:var(--brand-2);font-weight:500;margin-bottom:20px}
.hero-split-copy .lede{font-size:19px;line-height:1.55;color:var(--ink-2);margin-bottom:32px;max-width:540px}
.hero-split-copy .lede strong{color:var(--ink);font-weight:500}
.hero-split-copy .cta-row{display:flex;gap:14px;flex-wrap:wrap}

.hero-split-media{
  position:relative;border-radius:20px;overflow:hidden;
  aspect-ratio:4/5;
  background:var(--bg-2);
}
.hero-split-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease;
}
.hero-split-media:hover img{transform:scale(1.02)}
.hero-split-media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(155deg, transparent 55%, color-mix(in srgb,var(--brand) 18%,transparent)),
    linear-gradient(180deg, transparent 40%, color-mix(in srgb,var(--bg) 30%,transparent));
}
/* Photo credit overlay */
.hero-split-media .credit{
  position:absolute;bottom:16px;right:16px;z-index:1;
  font-size:11px;color:rgba(255,255,255,0.65);
  background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);
  padding:4px 10px;border-radius:100px;
  letter-spacing:0.02em;
}
.hero-split-media .credit a{color:inherit;text-decoration:underline;text-underline-offset:2px}

/* Image + text section */
.image-section{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
.image-section.reverse{direction:rtl}
.image-section.reverse > *{direction:ltr}
.image-section-media{
  border-radius:16px;overflow:hidden;
  aspect-ratio:4/3;background:var(--bg-2);
  position:relative;
}
.image-section-media img{width:100%;height:100%;object-fit:cover}
.image-section-copy h3{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(28px,3vw,42px);line-height:1.1;letter-spacing:-0.025em;
  color:var(--ink);margin-bottom:20px;
}
.image-section-copy h3 em{font-style:normal;color:var(--brand-2);font-weight:500}
.image-section-copy p{font-size:17px;line-height:1.6;color:var(--ink-2);margin-bottom:20px;max-width:52ch}
.image-section-copy p strong{color:var(--ink);font-weight:500}

/* Icon bubble - for cards and inclusions */
.icon-bubble{
  width:48px;height:48px;border-radius:12px;
  background:color-mix(in srgb,var(--brand) 12%,var(--bg-2));
  border:1px solid color-mix(in srgb,var(--brand) 20%,var(--line));
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:20px;color:var(--brand-2);
  transition:all 0.25s;
}
.icon-bubble svg{width:22px;height:22px}
.theme-light .icon-bubble{
  background:color-mix(in srgb,var(--brand) 8%,transparent);
}

/* Responsive */
@media(max-width:960px){
  .hero-split,.hero-split.reverse{grid-template-columns:1fr;gap:40px;padding:20px 0 56px}
  .hero-split.reverse .hero-split-media{order:0}
  .hero-split-media{aspect-ratio:4/3}
  .image-section,.image-section.reverse{grid-template-columns:1fr;gap:32px;direction:ltr}
}
