/*
Theme Name: Boyer, Tanzler & Sussman
Theme URI: https://boyersussman.com/
Author: XOVENT Ventures
Description: Editorial law-firm theme for Boyer, Tanzler & Sussman, P.A. Ships with four Elementor-built pages (Home, Practice Areas, Attorneys, Contact) pre-filled and ready to edit. Requires the free Elementor plugin.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: boyer-sussman
*/

:root{
  --ink:#16130f; --ink-soft:#2c2620; --paper:#f4efe6; --paper-2:#ece4d6;
  --stone:#8a7f6d; --stone-light:#b5ab98; --brass:#9a6a2f; --brass-bright:#c08a3e;
  --line:#d8cdb9; --white:#fbf8f1; --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Newsreader',Georgia,serif;font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--brass);color:var(--white)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;font-weight:600;color:var(--brass)}

/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,239,230,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 8px 30px -18px rgba(22,19,15,.4)}
.nav{max-width:var(--maxw);margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand .mark{font-family:'Fraunces',serif;font-weight:600;font-size:1.32rem;letter-spacing:-.01em;color:var(--ink)}
.brand .mark em{font-style:italic;color:var(--brass)}
.brand .sub{font-family:'Archivo',sans-serif;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone);margin-top:3px}
nav.menu{display:flex;align-items:center;gap:34px}
.menu a.lnk{font-family:'Archivo',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.04em;color:var(--ink-soft);position:relative;padding:4px 0;transition:color .25s}
.menu a.lnk::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--brass);transition:width .3s ease}
.menu a.lnk:hover{color:var(--ink)}
.menu a.lnk:hover::after,.menu a.lnk.active::after{width:100%}
.menu a.lnk.active{color:var(--ink)}
.call-btn{font-family:'Archivo',sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.04em;background:var(--ink);color:var(--white);padding:11px 20px;border-radius:2px;display:inline-flex;align-items:center;gap:8px;transition:background .25s,transform .2s}
.call-btn:hover{background:var(--brass);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* reveals */
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.reveal{opacity:0}
.reveal.in{animation:rise .8s cubic-bezier(.2,.7,.2,1) both}

/* HERO */
.hero{position:relative;overflow:hidden;padding:96px 0 88px;border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(1200px 500px at 78% -10%,rgba(154,106,47,.16),transparent 60%),radial-gradient(900px 600px at 0% 110%,rgba(22,19,15,.06),transparent 55%)}
.hero-bg::after{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;opacity:.25;-webkit-mask-image:radial-gradient(70% 70% at 70% 30%,#000,transparent);mask-image:radial-gradient(70% 70% at 70% 30%,#000,transparent)}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.hero h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(2.7rem,6vw,4.6rem);line-height:1.02;letter-spacing:-.02em;margin:22px 0 26px}
.hero h1 em{font-style:italic;color:var(--brass)}
.hero p.lead{font-size:1.18rem;color:var(--ink-soft);max-width:46ch;margin-bottom:34px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn-primary{font-family:'Archivo',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.03em;background:var(--ink);color:var(--white);padding:15px 28px;border-radius:2px;display:inline-flex;align-items:center;gap:10px;transition:.25s;cursor:pointer;border:none}
.btn-primary:hover{background:var(--brass);transform:translateY(-2px)}
.btn-ghost{font-family:'Archivo',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.03em;padding:15px 26px;border:1px solid var(--ink);border-radius:2px;display:inline-flex;align-items:center;gap:10px;transition:.25s;cursor:pointer}
.btn-ghost:hover{background:var(--ink);color:var(--white)}
.hero-card{position:relative;background:var(--white);border:1px solid var(--line);padding:38px 36px;border-radius:4px;box-shadow:0 40px 80px -50px rgba(22,19,15,.5)}
.hero-card .verdict{font-family:'Fraunces',serif;font-size:3.4rem;font-weight:600;color:var(--brass);line-height:1}
.hero-card .verdict-label{font-size:.98rem;color:var(--ink-soft);margin-top:6px}
.hero-card hr{border:none;border-top:1px solid var(--line);margin:26px 0}
.hero-card .stats{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.hero-card .stat .n{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:600}
.hero-card .stat .t{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone)}
.ribbon{position:absolute;top:-13px;left:32px;background:var(--brass);color:var(--white);font-family:'Archivo',sans-serif;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;padding:6px 14px;border-radius:2px;font-weight:600}

/* marquee */
.marquee{background:var(--ink);color:var(--paper);overflow:hidden;padding:13px 0;border-bottom:1px solid var(--line)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 34s linear infinite;font-family:'Archivo',sans-serif;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase}
.marquee-track span{display:inline-flex;align-items:center;gap:60px;color:var(--stone-light)}
.marquee-track b{color:var(--brass-bright);font-weight:600}
@keyframes scroll{to{transform:translateX(-50%)}}

/* sections */
.block{padding:92px 0}
.block.block--tight{padding-top:0}
.sec-head{max-width:62ch}
.sec-head h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.08;letter-spacing:-.015em;margin:16px 0 18px}
.sec-head h2 em{font-style:italic;color:var(--brass)}
.sec-head p{color:var(--ink-soft);font-size:1.12rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:8px}
.onside h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(2rem,4vw,2.9rem);line-height:1.08;margin:14px 0 22px;letter-spacing:-.015em}
.onside p{color:var(--ink-soft);margin-bottom:18px}
.pull{border-left:3px solid var(--brass);padding:6px 0 6px 22px;margin:28px 0;font-family:'Fraunces',serif;font-style:italic;font-size:1.32rem;color:var(--ink);line-height:1.4}

/* practice grid */
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);background:var(--line)}
.area{background:var(--paper);padding:30px 28px 34px;position:relative;transition:background .3s,transform .3s;min-height:178px;display:flex;flex-direction:column}
.area:hover{background:var(--white);transform:translateY(-2px);z-index:2;box-shadow:0 30px 50px -36px rgba(22,19,15,.5)}
.area .num{font-family:'Archivo',sans-serif;font-size:.7rem;letter-spacing:.2em;color:var(--stone);margin-bottom:14px}
.area h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.32rem;letter-spacing:-.01em;margin-bottom:9px;line-height:1.15}
.area p{font-size:.96rem;color:var(--ink-soft);line-height:1.5}
.area .arrow{margin-top:auto;color:var(--brass);font-size:1.1rem;opacity:0;transform:translateX(-6px);transition:.3s}
.area:hover .arrow{opacity:1;transform:none}

/* CTA band */
.band{background:var(--ink);color:var(--paper);position:relative;overflow:hidden;padding:84px 0}
.band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 85% 20%,rgba(192,138,62,.22),transparent 60%)}
.band .wrap{position:relative;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.band h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1.08;max-width:18ch}
.band h2 em{font-style:italic;color:var(--brass-bright)}
.band .btn-primary{background:var(--brass)}
.band .btn-primary:hover{background:var(--brass-bright)}

/* inner page heads */
.phead{padding:84px 0 40px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.phead::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 90% -20%,rgba(154,106,47,.12),transparent 60%)}
.phead .wrap{position:relative}
.phead h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(2.4rem,5vw,3.8rem);letter-spacing:-.02em;margin-top:14px;line-height:1.03}
.phead p{color:var(--ink-soft);max-width:65ch;margin-top:18px;font-size:1.12rem}

/* practice detail */
.pa-list{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:14px}
.pa-item{background:var(--white);border:1px solid var(--line);border-radius:4px;padding:30px 30px 32px;transition:.3s}
.pa-item:hover{transform:translateY(-3px);box-shadow:0 34px 60px -44px rgba(22,19,15,.5);border-color:var(--stone-light)}
.pa-item h3{font-family:'Fraunces',serif;font-weight:600;font-size:1.45rem;margin-bottom:10px;letter-spacing:-.01em}
.pa-item .desc{color:var(--ink-soft);font-size:1.02rem;margin-bottom:14px}
.pa-item ul{list-style:none}
.pa-item li{position:relative;padding-left:22px;color:var(--ink-soft);font-size:1rem;margin:7px 0}
.pa-item li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;background:var(--brass);transform:rotate(45deg)}
.pa-item.tall{grid-column:span 2}

/* attorneys */
.atty{display:grid;grid-template-columns:300px 1fr;gap:48px;padding:54px 0;border-bottom:1px solid var(--line);align-items:start}
.atty:last-child{border-bottom:none}
.atty-aside{position:sticky;top:110px}
.atty-portrait{width:100%;aspect-ratio:3/4;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:linear-gradient(160deg,var(--paper-2),var(--white));display:flex;align-items:flex-end;justify-content:center;position:relative;box-shadow:0 36px 70px -50px rgba(22,19,15,.6)}
.atty-portrait .mono{font-family:'Fraunces',serif;font-weight:600;font-size:5rem;color:var(--brass);opacity:.34;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.atty-portrait img{width:100%;height:100%;object-fit:cover}
.atty-name{font-family:'Fraunces',serif;font-weight:600;font-size:1.6rem;margin-top:20px;letter-spacing:-.01em}
.atty-role{font-family:'Archivo',sans-serif;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:600;margin-top:5px}
.atty-body p{color:var(--ink-soft);margin-bottom:16px}
.atty-body p em{font-style:italic;color:var(--ink)}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:26px}
.cred h4{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:9px;border-bottom:1px solid var(--line);padding-bottom:7px}
.cred p,.cred li{font-size:.96rem;color:var(--ink-soft);list-style:none;margin:5px 0}
.deceased{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:8px}
.field{margin-bottom:18px}
.field label{font-family:'Archivo',sans-serif;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);display:block;margin-bottom:7px}
.field input,.field textarea{width:100%;background:var(--white);border:1px solid var(--line);border-radius:3px;padding:13px 15px;font-family:'Newsreader',serif;font-size:1rem;color:var(--ink);transition:.2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(154,106,47,.12)}
.field textarea{resize:vertical;min-height:120px}
.info-card{background:var(--ink);color:var(--paper);border-radius:4px;padding:40px 38px}
.info-card h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.7rem;margin-bottom:24px}
.info-row{display:flex;gap:14px;margin-bottom:22px;align-items:flex-start}
.info-row .ic{color:var(--brass-bright);font-size:1.1rem;margin-top:2px}
.info-row .lab{font-family:'Archivo',sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-light);margin-bottom:3px}
.info-row a,.info-row span{color:var(--paper)}
.info-card .note{border-top:1px solid #322c24;margin-top:8px;padding-top:22px;font-size:.95rem;color:var(--stone-light)}
.formnote{font-size:.8rem;color:var(--stone);margin-top:6px}

/* FOOTER */
.site-footer{background:var(--paper-2);border-top:1px solid var(--line);padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.foot-grid .mark{font-family:'Fraunces',serif;font-weight:600;font-size:1.5rem}
.foot-grid .mark em{font-style:italic;color:var(--brass)}
.foot-grid p{color:var(--ink-soft);font-size:.98rem;margin-top:12px;max-width:38ch}
.foot-col h4{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);margin-bottom:14px}
.foot-col a,.foot-col p{display:block;font-size:.98rem;color:var(--ink-soft);margin:8px 0;transition:color .2s}
.foot-col a:hover{color:var(--brass)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-family:'Archivo',sans-serif;font-size:.78rem;color:var(--stone);letter-spacing:.02em}

/* full-bleed helper so Elementor sections span edge to edge */
.elementor-section.elementor-section-stretched,.elementor .hero,.elementor .band,.elementor .marquee{width:100%}

@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:44px}
  .split,.contact-grid{grid-template-columns:1fr;gap:36px}
  .areas{grid-template-columns:repeat(2,1fr)}
  .pa-list{grid-template-columns:1fr}
  .pa-item.tall{grid-column:span 1}
  .atty{grid-template-columns:1fr;gap:28px}
  .atty-aside{position:static;max-width:280px}
  .creds{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  body{font-size:17px}
  .wrap{padding:0 22px}
  .nav{padding:16px 22px}
  nav.menu{position:fixed;inset:0 0 0 auto;width:74%;max-width:320px;background:var(--paper);flex-direction:column;align-items:flex-start;padding:90px 32px;gap:8px;transform:translateX(100%);transition:transform .35s;box-shadow:-20px 0 60px -30px rgba(0,0,0,.4);z-index:60}
  nav.menu.open{transform:none}
  .menu a.lnk{font-size:1.1rem;padding:10px 0}
  .menu .call-btn{margin-top:14px}
  .burger{display:flex;z-index:61}
  .burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .areas{grid-template-columns:1fr}
  .creds{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .block{padding:64px 0}
  .band .wrap{flex-direction:column;align-items:flex-start}
}
.scrim{position:fixed;inset:0;background:rgba(22,19,15,.4);opacity:0;visibility:hidden;transition:.3s;z-index:55}
.scrim.show{opacity:1;visibility:visible}
