/*
Theme Name: CB Legal
Theme URI: https://cblegal.law
Author: CB Legal
Author URI: https://cblegal.law
Description: A refined one-page theme for CB Legal, a Roswell, Georgia real estate litigation and default services practice. Navy and slate palette drawn from the firm logo, with practice areas, counsel, FAQ, and a contact section.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cb-legal
*/

:root{
    --navy:#173044;
    --navy-2:#21425a;
    --navy-deep:#0d1f2c;
    --slate:#8a9cb1;
    --slate-lt:#a6b6c9;
    --accent:#4e6e8a;       /* steel — accents on light bg */
    --accent-lt:#8a9cb1;    /* slate — accents on dark bg */
    --paper:#f4f5f7;
    --paper-2:#e9edf2;
    --ink:#16293a;
    --muted:#56697b;
    --line:rgba(23,48,68,.13);
    --line-lt:rgba(244,245,247,.16);
    --shadow:0 30px 60px -28px rgba(13,31,44,.4);
    --maxw:1200px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.03;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
  h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.05;letter-spacing:-.015em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;color:var(--accent)}
  .dark .eyebrow,.eyebrow.on-dark{color:var(--accent-lt)}

  .btn{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:.92rem;letter-spacing:.01em;padding:.85em 1.5em;border-radius:2px;transition:.35s cubic-bezier(.2,.7,.3,1);cursor:pointer;border:1px solid transparent}
  .btn-primary{background:var(--slate);color:var(--navy)}
  .btn-primary:hover{background:var(--slate-lt);transform:translateY(-2px)}
  .btn-ghost{border-color:currentColor}
  .btn-ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
  .btn-ghost.on-dark:hover{background:var(--paper);color:var(--navy);border-color:var(--paper)}
  .btn .arrow{transition:transform .35s}
  .btn:hover .arrow{transform:translateX(4px)}

  /* nav */
  header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.4s}
  .nav{display:flex;align-items:center;justify-content:space-between;height:88px}
  header.scrolled{background:var(--paper);box-shadow:0 1px 0 var(--line)}
  header.scrolled .navlink,header.scrolled .nav-phone{color:var(--ink)}
  .brand img{display:block}
  .brand .lg{height:36px}
  .brand .lg-dark{display:none}
  header.scrolled .brand .lg-light{display:none}
  header.scrolled .brand .lg-dark{display:block}
  .navmenu{display:flex;align-items:center;gap:34px}
  .navlink{font-size:.86rem;font-weight:500;letter-spacing:.02em;color:#fff;transition:.3s;position:relative}
  .navlink::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--slate);transition:.3s}
  .navlink:hover::after{width:100%}
  .nav-cta{display:flex;align-items:center;gap:18px}
  .nav-phone{font-size:.86rem;font-weight:600;color:#fff;transition:.3s}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{width:26px;height:2px;background:#fff;transition:.3s}
  header.scrolled .burger span{background:var(--ink)}

  /* hero */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;background:linear-gradient(155deg,#0a1a26 0%,#143044 55%,#1c3c54 100%);color:#fff;overflow:hidden}
  .hero .survey{position:absolute;inset:0;opacity:.55;pointer-events:none}
  .hero .glow{position:absolute;width:60vw;height:60vw;right:-15vw;top:-12vw;border-radius:50%;background:radial-gradient(circle,rgba(138,156,177,.2),transparent 62%);pointer-events:none}
  .hero-inner{position:relative;z-index:3;padding:130px 0 90px;max-width:900px}
  .hero h1{font-size:clamp(2.7rem,6.2vw,5.3rem);font-weight:500;margin:.32em 0 .42em}
  .hero h1 em{font-style:italic;color:var(--slate-lt);font-weight:400}
  .hero p.lede{font-size:clamp(1.05rem,1.55vw,1.26rem);max-width:660px;color:rgba(255,255,255,.82);font-weight:400}
  .hero-cta{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap}
  .hero-meta{display:flex;gap:38px;margin-top:64px;flex-wrap:wrap;border-top:1px solid var(--line-lt);padding-top:28px}
  .hero-meta div{max-width:170px}
  .hero-meta div b{font-family:'Fraunces',serif;font-size:1.18rem;font-weight:500;color:var(--slate-lt);display:block;line-height:1.2}
  .hero-meta div span{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:7px;display:block}
  .scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;gap:10px}
  .scroll-hint .ln{width:1px;height:40px;background:linear-gradient(var(--slate),transparent);animation:drop 2.2s infinite}
  @keyframes drop{0%{opacity:0;transform:scaleY(.2)}40%{opacity:1}100%{opacity:0;transform:scaleY(1) translateY(12px)}}

  section{position:relative}
  .pad{padding:120px 0}.pad-sm{padding:88px 0}
  .section-head{max-width:660px;margin-bottom:60px}
  .section-head h2{font-size:clamp(2rem,3.8vw,3.1rem);margin:.3em 0 .4em}
  .section-head p{color:var(--muted);font-size:1.05rem}
  .dark{background:var(--navy);color:#fff}
  .dark .section-head h2{color:#fff}
  .dark .section-head p{color:rgba(255,255,255,.72)}

  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
  .card{background:var(--paper);padding:42px 34px;transition:.4s;position:relative}
  .card::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:.45s}
  .card:hover{background:#fff}
  .card:hover::before{transform:scaleX(1)}
  .card .num{font-family:'Fraunces',serif;font-size:.85rem;color:var(--accent);letter-spacing:.1em}
  .card h3{font-size:1.3rem;margin:18px 0 12px}
  .card p{font-size:.95rem;color:var(--muted)}
  .card .more{margin-top:18px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--accent);opacity:0;transform:translateY(6px);transition:.4s}
  .card:hover .more{opacity:1;transform:none}

  .split{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center}
  .about-vis{position:relative;aspect-ratio:4/5;background:linear-gradient(150deg,#1c3c54,#0c1d2a);overflow:hidden;border:1px solid var(--line)}
  .about-vis .survey2{position:absolute;inset:0;opacity:.55}
  .about-vis .seal{position:absolute;inset:0;display:grid;place-items:center}
  .about-vis .ring{width:190px;height:190px;border:1px solid var(--slate);border-radius:50%;display:grid;place-items:center;position:relative;padding:30px}
  .about-vis .ring::before{content:"";position:absolute;inset:12px;border:1px solid rgba(138,156,177,.4);border-radius:50%}
  .about-vis .ring img{width:120px;position:relative;z-index:2}
  .about-txt h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin:.3em 0 .55em}
  .about-txt p{color:var(--muted);margin-bottom:18px;font-size:1.04rem}
  .about-txt .sig{font-family:'Fraunces',serif;font-style:italic;font-size:1.35rem;color:var(--ink);margin-top:26px}
  .about-txt .sig span{display:block;font-family:'Hanken Grotesk';font-style:normal;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px}

  .why{display:grid;grid-template-columns:repeat(4,1fr);gap:46px}
  .why .item{border-top:1px solid var(--line-lt);padding-top:24px}
  .why .item .ic{width:36px;height:36px;color:var(--slate-lt);margin-bottom:20px}
  .why .item h4{font-size:1.16rem;margin-bottom:10px;color:#fff}
  .why .item p{font-size:.91rem;color:rgba(255,255,255,.68)}

  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);counter-reset:s}
  .step{background:var(--paper);padding:40px 30px;counter-increment:s}
  .step::before{content:"0" counter(s);font-family:'Fraunces',serif;font-size:2.3rem;color:var(--accent);display:block;margin-bottom:18px}
  .step h4{font-size:1.16rem;margin-bottom:10px}
  .step p{font-size:.92rem;color:var(--muted)}

  .matters{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
  .matter{border:1px solid var(--line-lt);padding:36px 30px;background:rgba(255,255,255,.025)}
  .matter .tag{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slate-lt);font-weight:600}
  .matter h4{font-size:1.4rem;margin:14px 0 12px;color:#fff;font-weight:500}
  .matter p{font-size:.94rem;color:rgba(255,255,255,.68)}

  .attys{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
  .atty{background:var(--paper);border:1px solid var(--line);transition:.4s}
  .atty:hover{background:#fff;box-shadow:var(--shadow);transform:translateY(-4px)}
  .atty .ph{aspect-ratio:1/1.05;background:linear-gradient(150deg,#21425a,#0d1f2c);display:grid;place-items:center;position:relative;overflow:hidden}
  .atty .ph .sv{position:absolute;inset:0;opacity:.4}
  .atty .ph .ini{font-family:'Fraunces',serif;font-size:2.5rem;color:var(--slate-lt);z-index:2;letter-spacing:.04em}
  .atty .info{padding:24px 24px 28px}
  .atty .info h4{font-size:1.2rem}
  .atty .info .role{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:7px 0 11px;font-weight:600}
  .atty .info p{font-size:.89rem;color:var(--muted)}

  .quote-wrap{max-width:900px;margin:0 auto;text-align:center}
  .quote-wrap .mark{font-family:'Fraunces',serif;font-size:5rem;color:var(--slate);line-height:.6;height:40px}
  .quote-wrap blockquote{font-family:'Fraunces',serif;font-size:clamp(1.4rem,2.6vw,2.05rem);font-weight:400;line-height:1.35;font-style:italic;margin:26px 0 30px}
  .quote-wrap cite{font-style:normal;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slate-lt)}

  .faq{max-width:840px;margin:0 auto}
  .faq details{border-bottom:1px solid var(--line);padding:6px 0}
  .faq summary{list-style:none;cursor:pointer;padding:26px 0;font-family:'Fraunces',serif;font-size:1.2rem;display:flex;justify-content:space-between;align-items:center;gap:20px}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary .pl{flex:0 0 auto;width:22px;height:22px;position:relative;transition:.3s}
  .faq summary .pl::before,.faq summary .pl::after{content:"";position:absolute;background:var(--accent);transition:.3s}
  .faq summary .pl::before{top:50%;left:0;width:100%;height:2px;transform:translateY(-50%)}
  .faq summary .pl::after{left:50%;top:0;height:100%;width:2px;transform:translateX(-50%)}
  .faq details[open] summary .pl::after{transform:translateX(-50%) scaleY(0)}
  .faq details[open] summary .pl{transform:rotate(180deg)}
  .faq .ans{padding:0 0 26px;color:var(--muted);font-size:1rem;max-width:92%}

  .contact{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;align-items:start}
  .contact-info h2{font-size:clamp(2rem,3.6vw,3rem);margin:.3em 0 .5em;color:#fff}
  .contact-info p{color:rgba(255,255,255,.74);margin-bottom:30px;font-size:1.05rem}
  .contact-row{display:flex;gap:16px;padding:20px 0;border-top:1px solid var(--line-lt)}
  .contact-row .ic{color:var(--slate-lt);flex:0 0 auto;margin-top:2px}
  .contact-row b{display:block;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:4px;font-weight:600}
  .contact-row span{font-size:1.02rem}
  form{background:var(--paper);padding:42px;border:1px solid var(--line)}
  .field{margin-bottom:22px}
  .field label{display:block;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--muted);margin-bottom:9px}
  .field input,.field select,.field textarea{width:100%;padding:14px 16px;border:1px solid var(--line);background:#fff;font-family:inherit;font-size:.98rem;color:var(--ink);border-radius:2px;transition:.3s}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(78,110,138,.12)}
  .field textarea{resize:vertical;min-height:120px}
  .field.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .form-note{font-size:.82rem;color:var(--muted);margin-top:8px}
  .form-success{display:none;background:var(--navy);color:#fff;padding:20px;border-radius:2px;margin-bottom:22px;font-size:.95rem}
  .form-success.show{display:block}

  footer{background:var(--navy-deep);color:rgba(255,255,255,.62);padding:78px 0 36px}
  .foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:52px;border-bottom:1px solid var(--line-lt)}
  .foot-brand img{height:40px;margin-bottom:18px;display:block}
  .foot-brand p{font-size:.92rem;max-width:300px}
  .foot-col h5{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slate-lt);margin-bottom:18px;font-weight:600}
  .foot-col a{display:block;font-size:.92rem;margin-bottom:11px;transition:.3s}
  .foot-col a:hover{color:#fff}
  .foot-bottom{padding-top:30px;display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;font-size:.8rem;color:rgba(255,255,255,.42)}
  .disclaimer{margin-top:24px;font-size:.76rem;line-height:1.7;color:rgba(255,255,255,.4);max-width:960px}

  .reveal{opacity:0;transform:translateY(28px);transition:.9s cubic-bezier(.2,.7,.3,1)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
  .reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

  @media(max-width:1000px){
    .grid,.steps{grid-template-columns:repeat(2,1fr)}
    .why,.attys{grid-template-columns:repeat(2,1fr)}
    .matters{grid-template-columns:1fr}
    .split,.contact{grid-template-columns:1fr;gap:46px}
    .about-vis{aspect-ratio:16/10;order:-1}
  }
  @media(max-width:720px){
    .navmenu,.nav-phone{display:none}
    .burger{display:flex}
    .navmenu.open{display:flex;position:absolute;top:88px;left:0;right:0;flex-direction:column;background:var(--paper);padding:28px;gap:22px;box-shadow:var(--shadow)}
    .navmenu.open .navlink{color:var(--ink)}
    .pad{padding:82px 0}
    .grid,.steps,.why,.attys{grid-template-columns:1fr}
    .field.two{grid-template-columns:1fr}
    .foot-top{grid-template-columns:1fr 1fr}
    .hero-meta{gap:26px}
  }

/* ===== Attorney cards as links + photo support ===== */
.atty{display:block;color:inherit;text-decoration:none}
.atty .ph::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(138,156,177,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(138,156,177,.12) 1px,transparent 1px);background-size:40px 40px}
.atty .ph .photo,.atty .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:3}
.atty .ph .ini{position:relative;z-index:2}

/* ===== Solid header on inner pages (no dark hero behind it) ===== */
header.solid{background:var(--paper);box-shadow:0 1px 0 var(--line)}
header.solid .navlink,header.solid .nav-phone{color:var(--ink)}
header.solid .brand .lg-light{display:none}
header.solid .brand .lg-dark{display:block}
header.solid .burger span{background:var(--ink)}

/* ===== Inner page top offset (fixed header) ===== */
.inner-top{padding-top:140px}

/* ===== Attorney bio page ===== */
.atty-single{padding:0 0 110px;background:var(--paper)}
.back-link{display:inline-block;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--accent);margin-bottom:14px;transition:.3s}
.back-link:hover{color:var(--navy)}
.bio{display:grid;grid-template-columns:320px 1fr;gap:64px;align-items:start;margin-top:8px}
.bio-aside{position:sticky;top:118px}
.bio-photo{aspect-ratio:1/1.1;background:linear-gradient(150deg,#21425a,#0d1f2c);display:grid;place-items:center;position:relative;overflow:hidden;border:1px solid var(--line)}
.bio-photo::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(138,156,177,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(138,156,177,.12) 1px,transparent 1px);background-size:40px 40px}
.bio-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:3}
.bio-photo .ini{font-family:'Fraunces',serif;font-size:3.4rem;color:var(--slate-lt);z-index:2;letter-spacing:.04em}
.bio-contact{margin-top:24px}
.bio-contact .btn{width:100%;justify-content:center}
.bio-contact p{margin-top:16px;font-size:.95rem;color:var(--muted);line-height:1.9}
.bio-contact a{color:var(--accent)}
.bio-main h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin:.05em 0 .5em}
.bio-main .eyebrow{display:block;margin-bottom:8px}
.bio-body{color:var(--muted);font-size:1.06rem;line-height:1.75}
.bio-body p{margin-bottom:18px}
.bio-body h2,.bio-body h3{font-family:'Fraunces',serif;color:var(--ink);margin:1.3em 0 .5em}
.bio-body a{color:var(--accent);text-decoration:underline}
.bio-body ul,.bio-body ol{margin:0 0 18px 1.2em}
.bio-body li{margin-bottom:8px}
@media(max-width:900px){
  .bio{grid-template-columns:1fr;gap:34px}
  .bio-aside{position:static}
  .bio-photo{aspect-ratio:16/10;max-width:380px}
}

/* ===== Contact Form 7 — match the theme's contact form ===== */
.wpcf7{max-width:100%}
.wpcf7 .field input.wpcf7-form-control,
.wpcf7 .field select.wpcf7-form-control,
.wpcf7 .field textarea.wpcf7-form-control{width:100%}
.wpcf7 .btn,.wpcf7 input[type="submit"]{width:100%;justify-content:center;font-family:inherit}
.wpcf7-spinner{display:block;margin:14px auto 0}
.wpcf7 .wpcf7-response-output{margin:18px 0 0;padding:14px 16px;border-radius:2px;font-size:.92rem;border:0}
.wpcf7 form.sent .wpcf7-response-output{background:var(--navy);color:#fff}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output{background:#f7e7e7;color:#8a2b2b}
.wpcf7-not-valid-tip{color:#c0392b;font-size:.8rem;margin-top:6px;font-weight:600}
.wpcf7 .field input.wpcf7-not-valid,
.wpcf7 .field select.wpcf7-not-valid,
.wpcf7 .field textarea.wpcf7-not-valid{border-color:#c0392b}
