/*
Theme Name: Docs n Dots Landing
Theme URI: https://docsnDots.com/
Author: Docs n Dots
Description: Custom landing page theme converted from the provided Docs n Dots HTML design.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: docs-n-dots-landing
*/

:root {
      --bg:#ffffff;
      --ink:#0a0a0a;
      --muted:#565656;
      --soft:#f7f7f5;
      --soft2:#eeeeeb;
      --line:#dfdfdc;
      --dark:#050505;
      --card:#ffffff;
      --shadow:0 20px 50px rgba(0,0,0,.08);
      --radius:24px;
      --max:1180px;
    }
    * { box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    body { margin:0; background:var(--bg); color:var(--ink); font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif; line-height:1.45; }
    img { max-width:100%; display:block; }
    a { color:inherit; text-decoration:none; }
    button, a.button { min-height:48px; }
    .wrap { width:min(var(--max), calc(100% - 40px)); margin-inline:auto; }
    .skip { position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden; }
    .skip:focus { left:20px; top:20px; width:auto; height:auto; z-index:99; background:#fff; border:2px solid #000; padding:10px 14px; }
    header { position:sticky; top:0; z-index:50; background:rgba(255,255,255,.94); backdrop-filter: blur(18px); border-bottom:1px solid var(--line); }
    .nav { height:86px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
    .brand { display:flex; align-items:center; gap:12px; min-width:155px; }
    .brand img { width:138px; height:54px; object-fit:contain; object-position:left center; mix-blend-mode:multiply; }
    nav ul { list-style:none; padding:0; margin:0; display:flex; align-items:center; gap:34px; font-weight:750; font-size:14px; }
    nav a { padding-block:8px; border-bottom:2px solid transparent; }
    nav a:hover, nav a:focus-visible { border-color:#000; outline:none; }
    .menu-btn { display:none; border:1px solid var(--line); background:#fff; border-radius:999px; padding:10px 14px; font-weight:800; }
    .button { display:inline-flex; align-items:center; justify-content:center; gap:10px; border-radius:10px; padding:13px 18px; font-weight:850; font-size:14px; border:1px solid #000; transition:transform .15s ease, box-shadow .15s ease; cursor:pointer; }
    .button:hover { transform:translateY(-1px); box-shadow:0 10px 22px rgba(0,0,0,.12); }
    .button.dark { background:#000; color:#fff; }
    .button.light { background:#fff; color:#000; }
    main { overflow:hidden; }
    .hero { padding:58px 0 34px; }
    .hero-grid { display:grid; grid-template-columns: .95fr 1.05fr; align-items:center; gap:42px; }
    .eyebrow { letter-spacing:.16em; text-transform:uppercase; font-weight:900; color:#111; font-size:13px; margin:0 0 20px; }
    h1 { font-size:clamp(44px, 5.5vw, 74px); line-height:.98; letter-spacing:-.055em; margin:0 0 24px; max-width:720px; }
    .script { font-family:Georgia, serif; font-style:italic; font-weight:500; letter-spacing:-.035em; border-bottom:5px solid #000; line-height:.8; }
    .lead { font-size:18px; max-width:575px; color:#202020; margin:0 0 28px; }
    .cta-row { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:34px; }
    .trust-row { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:26px; }
    .trust { display:flex; gap:12px; align-items:flex-start; }
    .ico { flex:0 0 42px; width:42px; height:42px; border:2px solid #000; border-radius:50%; display:grid; place-items:center; font-weight:900; background:#fff; }
    .trust strong { display:block; font-size:14px; margin-bottom:3px; }
    .trust span { color:var(--muted); font-size:13px; display:block; }
    .hero-media { position:relative; min-height:560px; border-radius:0 0 0 90px; overflow:hidden; background:var(--soft); }
    .hero-media img { width:100%; height:100%; min-height:560px; object-fit:cover; object-position:center top; }
    .phone-card { position:absolute; right:4%; bottom:5%; width:min(295px, 46%); background:#fff; border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow); padding:20px; }
    .phone-top { display:flex; justify-content:space-between; font-size:12px; font-weight:800; margin-bottom:16px; }
    .phone-card h3 { margin:0 0 5px; font-size:17px; }
    .phone-card p { margin:0 0 16px; color:var(--muted); font-size:12px; }
    .stats { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:14px; }
    .stat { border:1px solid var(--line); border-radius:12px; padding:9px; background:#fafafa; }
    .stat b { display:block; font-size:22px; }
    .stat small { color:var(--muted); font-size:10px; }
    .mini-list { display:grid; gap:9px; font-size:12px; }
    .mini-list div { display:flex; justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:7px; }
    .service-intro { padding:46px 0 18px; text-align:center; }
    .kicker { text-transform:uppercase; letter-spacing:.16em; font-size:12px; font-weight:900; color:#111; margin:0 0 8px; }
    h2 { font-size:clamp(34px, 4.2vw, 54px); letter-spacing:-.04em; line-height:1.02; margin:0; }
    .panels { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; padding:22px 0 54px; }
    .panel { border:1px solid var(--line); border-radius:20px; overflow:hidden; background:#fff; box-shadow:0 12px 35px rgba(0,0,0,.045); }
    .panel-img { height:260px; overflow:hidden; background:#eee; position:relative; }
    .panel-img img { width:100%; height:100%; object-fit:cover; object-position:center top; }
    .badge { position:absolute; top:18px; left:18px; background:#000; color:#fff; border-radius:9px; padding:10px 12px; font-weight:900; }
    .panel-body { padding:28px 26px 30px; }
    .panel-body .label { text-transform:uppercase; letter-spacing:.12em; font-weight:900; font-size:12px; margin-bottom:12px; }
    .panel h3 { font-size:27px; line-height:1.08; letter-spacing:-.03em; margin:0 0 14px; }
    .panel p { color:#2b2b2b; margin:0 0 18px; }
    .checks { list-style:none; margin:0 0 24px; padding:0; display:grid; gap:9px; font-size:14px; }
    .checks li { display:flex; gap:10px; align-items:flex-start; }
    .checks li::before { content:"✓"; display:inline-grid; place-items:center; flex:0 0 18px; width:18px; height:18px; border-radius:50%; background:#000; color:#fff; font-size:12px; font-weight:900; margin-top:1px; }
    .steps-section { background:linear-gradient(#fff, var(--soft)); padding:42px 0 54px; }
    .steps-head { text-align:center; margin-bottom:36px; }
    .steps { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; position:relative; }
    .step { text-align:center; position:relative; }
    .step .bubble { width:86px; height:86px; border-radius:50%; background:#f1f1ef; border:1px solid var(--line); display:grid; place-items:center; margin:0 auto 14px; font-size:32px; }
    .step .num { width:25px; height:25px; border-radius:50%; background:#000; color:#fff; font-size:12px; font-weight:900; display:grid; place-items:center; position:absolute; top:58px; left:calc(50% - 46px); }
    .step strong { display:block; font-size:15px; margin-bottom:5px; }
    .step span { color:var(--muted); font-size:13px; display:block; max-width:150px; margin:auto; }
    .cta-band { padding:0 0 54px; }
    .band { display:grid; grid-template-columns:260px 1fr auto; align-items:center; gap:28px; border:1px solid var(--line); border-radius:20px; background:#fff; overflow:hidden; box-shadow:0 12px 35px rgba(0,0,0,.045); }
    .band img { width:100%; height:170px; object-fit:cover; object-position:center top; }
    .band h2 { font-size:30px; margin-bottom:6px; }
    .band p { color:var(--muted); margin:0; }
    .band-actions { display:flex; gap:12px; padding-right:28px; flex-wrap:wrap; }
    footer { background:#050505; color:#fff; padding:46px 0 22px; }
    .footer-grid { display:grid; grid-template-columns:1.4fr .7fr .9fr .9fr; gap:34px; border-bottom:1px solid rgba(255,255,255,.18); padding-bottom:32px; }
    footer img { width:120px; height:50px; object-fit:contain; filter:invert(1) grayscale(1); mix-blend-mode:screen; margin-bottom:12px; }
    footer p, footer li, footer a { color:#ededed; font-size:14px; }
    footer ul { list-style:none; padding:0; margin:10px 0 0; display:grid; gap:8px; }
    footer h3 { margin:0 0 12px; font-size:15px; }
    .copyright { text-align:center; color:#ccc; font-size:13px; padding-top:20px; }
    .focusable:focus-visible, .button:focus-visible, button:focus-visible { outline:3px solid #000; outline-offset:3px; }
    @media (max-width: 940px) {
      .nav { height:auto; padding:14px 0; align-items:flex-start; }
      .menu-btn { display:inline-flex; }
      nav { position:absolute; left:20px; right:20px; top:76px; background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow); padding:16px; display:none; }
      nav.open { display:block; }
      nav ul { display:grid; gap:12px; }
      .hero-grid { grid-template-columns:1fr; }
      .hero-media { min-height:430px; border-radius:28px; }
      .hero-media img { min-height:430px; }
      .trust-row { grid-template-columns:repeat(2,1fr); }
      .panels { grid-template-columns:1fr; }
      .panel-img { height:340px; }
      .steps { grid-template-columns:1fr; gap:26px; }
      .band { grid-template-columns:1fr; }
      .band img { height:260px; }
      .band > div:not(.band-actions) { padding:0 24px; }
      .band-actions { padding:0 24px 26px; }
      .footer-grid { grid-template-columns:1fr 1fr; }
    }
    @media (max-width: 560px) {
      .wrap { width:min(100% - 28px, var(--max)); }
      h1 { font-size:42px; }
      .hero { padding-top:34px; }
      .cta-row, .band-actions { flex-direction:column; }
      .button { width:100%; }
      .trust-row { grid-template-columns:1fr; }
      .phone-card { display:block; position:relative; right:auto; bottom:auto; width:100%; margin-top:14px; border-radius:20px; }
      .panel-img { height:270px; }
      .footer-grid { grid-template-columns:1fr; }
    }
  
.brand-text{
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #000;
  text-decoration: none;
  white-space: nowrap;
}
@media (max-width: 768px){
  .brand-text{font-size:1.4rem;}
}

/* WordPress/mobile lock additions */
@media (max-width: 560px) {
  .hero-grid { gap: 22px; }
  .hero-media { min-height: auto; display: grid; gap: 0; overflow: visible; background: transparent; }
  .hero-media img { min-height: 360px; border-radius: 24px; overflow: hidden; }
  .phone-card { box-shadow: 0 16px 32px rgba(0,0,0,.10); }
  .stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .trust-row { margin-top: 22px; }
  .panel { border-radius: 20px; }
  .step .bubble { width: 76px; height: 76px; font-size: 28px; }
  .step .num { top: 50px; }
}
.admin-bar header { top:32px; }
@media (max-width:782px){ .admin-bar header { top:46px; } }
