/* ========================================================================
   Tal Ben Shushan Law Office — Design System
   Boutique defamation-law firm · Hebrew RTL · Editorial law-review motif
   ======================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Assistant:wght@300;400;500;600;700&family=Frank+Ruhl+Libre:wght@400;500;700;900&display=swap');

:root{
    /* Palette — warm parchment with deep navy ink & muted bronze */
    --bg: #F4EFE6;
    --bg-2: #EFE8DB;
    --surface: #FBF8F2;
    --surface-alt: #FFFFFF;
    --dark-surface: #14182A;
    --dark-surface-2: #1C2238;

    --ink: #14182A;
    --ink-2: #2F3647;
    --muted: #6F7583;
    --muted-soft: #9A9EA9;

    --border: #E5DECE;
    --border-strong: #C9BFA8;
    --hairline: rgba(20, 24, 42, 0.08);

    --accent: #A98456;
    --accent-dark: #8A6A3D;
    --accent-soft: #D5BE94;
    --accent-glow: rgba(169, 132, 86, 0.18);
    --oxblood: #6A1A2E;

    --shadow-sm: 0 1px 2px rgba(20, 24, 42, 0.04), 0 2px 6px rgba(20, 24, 42, 0.04);
    --shadow-md: 0 4px 12px rgba(20, 24, 42, 0.06), 0 8px 30px rgba(20, 24, 42, 0.06);
    --shadow-lg: 0 12px 40px rgba(20, 24, 42, 0.10);

    --radius-sm: 2px;
    --radius-md: 4px;

    --ease: cubic-bezier(0.22, 1, 0.36, 1);

    --container: 1240px;
    --gutter: 1.5rem;

    --ff-display: 'Frank Ruhl Libre', 'Assistant', Georgia, serif;
    --ff-body: 'Assistant', 'Heebo', system-ui, -apple-system, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    margin:0;
    font-family:var(--ff-body);
    font-weight:400;
    font-size:1rem;
    line-height:1.7;
    color:var(--ink-2);
    background:var(--bg);
    direction:rtl;
    text-align:right;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
}

img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--ink);text-decoration:none;transition:color 0.3s var(--ease)}
a:hover{color:var(--accent)}
button{font-family:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
ul,ol{margin:0;padding:0}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}

::selection{background:var(--accent);color:#fff}

/* ------------------------------------------------------------------
   Typography
   ------------------------------------------------------------------ */
h1,h2,h3,h4,h5,h6{
    font-family:var(--ff-display);
    font-weight:500;
    color:var(--ink);
    margin:0 0 0.6em;
    letter-spacing:-0.01em;
    line-height:1.15;
}
h1{font-size:clamp(2.5rem, 5vw + 1rem, 5rem);font-weight:500;line-height:1.05}
h2{font-size:clamp(2rem, 3vw + 1rem, 3.25rem);font-weight:500}
h3{font-size:clamp(1.5rem, 1.5vw + 0.5rem, 2rem)}
h4{font-size:1.375rem}
h5{font-size:1.125rem}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}

.display-xl{
    font-family:var(--ff-display);
    font-size:clamp(3rem, 7vw, 7rem);
    font-weight:500;
    line-height:0.98;
    letter-spacing:-0.02em;
    color:var(--ink);
}

.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:0.75rem;
    font-family:var(--ff-body);
    font-size:0.75rem;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:0.2em;
    color:var(--accent);
}
.eyebrow::before{
    content:"";
    width:32px;
    height:1px;
    background:var(--accent);
}

.section-number{
    font-family:var(--ff-display);
    font-size:0.9rem;
    font-weight:500;
    color:var(--accent);
    letter-spacing:0.05em;
}

.lead{
    font-size:1.25rem;
    line-height:1.6;
    color:var(--ink-2);
    font-weight:300;
}

.kicker{
    font-family:var(--ff-body);
    font-size:0.8rem;
    text-transform:uppercase;
    letter-spacing:0.25em;
    color:var(--muted);
    font-weight:600;
}

/* ------------------------------------------------------------------
   Layout helpers
   ------------------------------------------------------------------ */
.container{
    width:100%;
    max-width:var(--container);
    margin:0 auto;
    padding-inline:var(--gutter);
}
.container-narrow{max-width:900px}
.container-wide{max-width:1400px}

section{position:relative;padding-block:clamp(4rem,8vw,8rem)}
.section-divider{
    height:1px;
    background:var(--border);
    max-width:var(--container);
    margin:0 auto;
}

.grid{display:grid;gap:2rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){
    .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
}

/* ------------------------------------------------------------------
   Buttons
   ------------------------------------------------------------------ */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:0.6rem;
    padding:0.95rem 1.8rem;
    font-family:var(--ff-body);
    font-size:0.95rem;
    font-weight:600;
    letter-spacing:0.02em;
    border-radius:var(--radius-sm);
    transition:all 0.35s var(--ease);
    cursor:pointer;
    text-decoration:none;
    border:1px solid transparent;
    white-space:nowrap;
}
.btn--primary{
    background:var(--ink);
    color:var(--surface);
}
.btn--primary:hover{
    background:var(--accent);
    color:#fff;
    transform:translateY(-2px);
    box-shadow:var(--shadow-md);
}
.btn--accent{
    background:var(--accent);
    color:#fff;
}
.btn--accent:hover{
    background:var(--accent-dark);
    color:#fff;
    transform:translateY(-2px);
    box-shadow:var(--shadow-md);
}
.btn--ghost{
    background:transparent;
    color:var(--ink);
    border-color:var(--border-strong);
}
.btn--ghost:hover{
    background:var(--ink);
    color:var(--surface);
    border-color:var(--ink);
}
.btn--light{
    background:rgba(255,255,255,0.95);
    color:var(--ink);
    backdrop-filter:blur(6px);
}
.btn--light:hover{
    background:#fff;
    transform:translateY(-2px);
    box-shadow:var(--shadow-lg);
}
.btn--link{
    padding:0;
    color:var(--ink);
    background:transparent;
    position:relative;
}
.btn--link::after{
    content:"";
    position:absolute;
    bottom:-3px;
    right:0;
    width:100%;
    height:1px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:right;
    transition:transform 0.4s var(--ease);
}
.btn--link:hover::after{transform:scaleX(1)}
.btn--link:hover{color:var(--accent)}

.btn .arrow{
    display:inline-block;
    transition:transform 0.35s var(--ease);
    font-size:0.95em;
}
.btn:hover .arrow{transform:translateX(-4px)} /* RTL: arrow points left, moves left on hover */

/* ------------------------------------------------------------------
   Navigation
   ------------------------------------------------------------------ */
.site-header{
    position:sticky;
    top:0;
    z-index:100;
    background:rgba(244, 239, 230, 0.82);
    backdrop-filter:blur(16px) saturate(140%);
    -webkit-backdrop-filter:blur(16px) saturate(140%);
    border-bottom:1px solid transparent;
    transition:background 0.3s var(--ease), border-color 0.3s var(--ease);
}
.site-header.is-scrolled{
    background:rgba(244, 239, 230, 0.96);
    border-bottom-color:var(--border);
}
.nav{
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:78px;
    gap:2rem;
}
.brand{
    display:flex;
    align-items:center;
    gap:0.75rem;
    text-decoration:none;
}
.brand-mark{
    width:42px;
    height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid var(--ink);
    color:var(--ink);
    font-family:var(--ff-display);
    font-size:1.1rem;
    font-weight:500;
    letter-spacing:0.02em;
    transition:all 0.3s var(--ease);
}
.brand:hover .brand-mark{background:var(--ink);color:var(--surface)}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-name{
    font-family:var(--ff-display);
    font-size:1.05rem;
    font-weight:500;
    color:var(--ink);
}
.brand-sub{
    font-size:0.7rem;
    font-weight:500;
    letter-spacing:0.2em;
    text-transform:uppercase;
    color:var(--muted);
}
.nav-menu{
    display:flex;
    align-items:center;
    gap:2.2rem;
    list-style:none;
}
.nav-link{
    font-size:0.95rem;
    font-weight:500;
    color:var(--ink-2);
    position:relative;
    padding:0.25rem 0;
}
.nav-link::after{
    content:"";
    position:absolute;
    bottom:-4px;
    right:0;
    width:100%;
    height:1px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:right;
    transition:transform 0.35s var(--ease);
}
.nav-link:hover,.nav-link.active{color:var(--ink)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}

.nav-cta{
    display:inline-flex;
    align-items:center;
}

.nav-toggle{
    display:none;
    width:44px;
    height:44px;
    align-items:center;
    justify-content:center;
    gap:5px;
    flex-direction:column;
    background:transparent;
    border:1px solid var(--border-strong);
    border-radius:var(--radius-sm);
}
.nav-toggle span{
    display:block;
    width:20px;
    height:1.5px;
    background:var(--ink);
    transition:transform 0.3s var(--ease), opacity 0.3s var(--ease);
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (max-width:900px){
    .nav-menu,.nav-cta{display:none}
    .nav-toggle{display:flex}
    .site-header.is-menu-open .nav-menu,
    .site-header.is-menu-open .nav-cta{
        display:flex;
        position:absolute;
        top:100%;
        right:0;
        left:0;
        background:var(--surface);
        border-bottom:1px solid var(--border);
        padding:1.25rem var(--gutter);
    }
    .site-header.is-menu-open .nav-menu{
        flex-direction:column;
        align-items:flex-start;
        gap:1rem;
        padding-bottom:0.5rem;
    }
    .site-header.is-menu-open .nav-cta{
        padding-top:0.75rem;
        padding-bottom:1.5rem;
        top:calc(100% + 200px);
    }
    .site-header.is-menu-open .nav-menu{padding-bottom:2rem}
    .site-header.is-menu-open .nav-cta{
        position:absolute;
        top:auto;
        bottom:-72px;
    }
}

/* ------------------------------------------------------------------
   Hero — editorial, parallax AI image + overlay
   ------------------------------------------------------------------ */
.hero{
    position:relative;
    min-height:min(88vh, 820px);
    display:flex;
    align-items:flex-end;
    padding:9rem 0 5rem;
    overflow:hidden;
    isolation:isolate;
}
.hero-bg{
    position:absolute;
    inset:0;
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
    z-index:-2;
}
.hero-bg::before,
.hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
}
.hero::before{
    background:
        linear-gradient(180deg, rgba(20,24,42,0.35) 0%, rgba(20,24,42,0.55) 55%, rgba(20,24,42,0.78) 100%);
}
.hero--home .hero-bg{background-image:url('_uploads/ai_1df1731e755d7248.jpg')}
.hero--services .hero-bg{background-image:url('_uploads/ai_e13ca3aa7f215f06.jpg')}
.hero--about .hero-bg{background-image:url('_uploads/ai_fa57b72c375815fc.jpg')}

.hero-content{
    position:relative;
    z-index:1;
    color:#F7F1E3;
    max-width:900px;
}
.hero .eyebrow{color:var(--accent-soft)}
.hero .eyebrow::before{background:var(--accent-soft)}
.hero h1{color:#FBF6EB}
.hero .lead{color:rgba(251,246,235,0.85);margin-top:1.5rem;max-width:640px}
.hero-actions{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{
    position:absolute;
    bottom:2.5rem;
    left:var(--gutter);
    right:auto;
    display:flex;
    align-items:center;
    gap:1.5rem;
    color:rgba(251,246,235,0.7);
    font-size:0.8rem;
    text-transform:uppercase;
    letter-spacing:0.2em;
    z-index:1;
}
.hero-meta::before{
    content:"";
    width:60px;
    height:1px;
    background:var(--accent-soft);
}

/* Page hero (smaller, for inner pages) */
.page-hero{
    min-height:min(60vh, 520px);
    padding:8rem 0 3rem;
}
.page-hero h1{font-size:clamp(2.25rem, 4vw + 1rem, 4rem)}

/* ------------------------------------------------------------------
   Home — intro / value proposition
   ------------------------------------------------------------------ */
.intro{
    background:var(--bg);
    padding-block:clamp(5rem,8vw,8rem);
}
.intro-grid{
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:clamp(3rem, 6vw, 6rem);
    align-items:start;
}
.intro-heading h2{font-size:clamp(2rem, 3vw + 0.5rem, 3rem);max-width:12ch}
.intro-body p{font-size:1.08rem;line-height:1.85;color:var(--ink-2)}
.intro-body p + p{margin-top:1.2rem}
.intro-body .values{
    margin-top:2rem;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1rem 2rem;
    padding-top:1.5rem;
    border-top:1px solid var(--border);
}
.value-item{
    font-size:0.9rem;
    font-weight:600;
    color:var(--ink);
    display:flex;
    align-items:center;
    gap:0.5rem;
}
.value-item::before{
    content:"";
    width:6px;
    height:6px;
    background:var(--accent);
    border-radius:50%;
}
@media (max-width:900px){
    .intro-grid{grid-template-columns:1fr;gap:2rem}
    .intro-body .values{grid-template-columns:repeat(2,1fr)}
}

/* ------------------------------------------------------------------
   Stats / Achievements
   ------------------------------------------------------------------ */
.stats-band{
    background:var(--dark-surface);
    color:#F7F1E3;
    position:relative;
    overflow:hidden;
}
.stats-band::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(1200px 500px at 80% 0%, rgba(169,132,86,0.18), transparent 60%),
        radial-gradient(800px 400px at 10% 100%, rgba(169,132,86,0.12), transparent 70%);
    pointer-events:none;
}
.stats-grid{
    position:relative;
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:1px;
    background:rgba(169,132,86,0.22);
    border:1px solid rgba(169,132,86,0.22);
}
.stat{
    padding:3rem 2rem;
    background:var(--dark-surface);
    transition:background 0.4s var(--ease);
}
.stat:hover{background:var(--dark-surface-2)}
.stat-number{
    font-family:var(--ff-display);
    font-size:clamp(2.5rem, 5vw, 4rem);
    font-weight:500;
    color:var(--accent-soft);
    line-height:1;
    display:flex;
    align-items:baseline;
    gap:0.2rem;
}
.stat-number .plus{font-size:0.6em;color:var(--accent)}
.stat-label{
    margin-top:1rem;
    font-size:0.95rem;
    color:rgba(247,241,227,0.72);
    line-height:1.5;
}
@media (max-width:900px){
    .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:500px){
    .stats-grid{grid-template-columns:1fr}
}

/* ------------------------------------------------------------------
   Section header (shared)
   ------------------------------------------------------------------ */
.section-head{
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:2rem;
    align-items:end;
    margin-bottom:3.5rem;
    padding-bottom:1.25rem;
    border-bottom:1px solid var(--border);
}
.section-head h2{margin:0;font-size:clamp(1.75rem, 2.5vw + 0.5rem, 2.75rem)}
.section-head .section-num{
    font-family:var(--ff-display);
    font-size:0.95rem;
    color:var(--accent);
    letter-spacing:0.15em;
    padding-top:0.25rem;
}
.section-head .section-link{
    font-size:0.9rem;
    color:var(--ink);
    text-decoration:none;
    white-space:nowrap;
    border-bottom:1px solid var(--accent);
    padding-bottom:3px;
    transition:color 0.3s var(--ease);
}
.section-head .section-link:hover{color:var(--accent)}
@media (max-width:720px){
    .section-head{grid-template-columns:1fr;gap:0.75rem}
    .section-head .section-link{justify-self:start}
}

/* ------------------------------------------------------------------
   Services / Practice areas — bento editorial grid
   ------------------------------------------------------------------ */
.practice-grid{
    display:grid;
    grid-template-columns:repeat(12, 1fr);
    gap:1px;
    background:var(--border);
    border:1px solid var(--border);
}
.practice-card{
    grid-column:span 4;
    background:var(--surface);
    padding:2.5rem 2rem;
    position:relative;
    transition:background 0.4s var(--ease), transform 0.4s var(--ease);
    overflow:hidden;
}
.practice-card:nth-child(1){grid-column:span 6}
.practice-card:nth-child(2){grid-column:span 6}
.practice-card:nth-child(3){grid-column:span 4}
.practice-card:nth-child(4){grid-column:span 4}
.practice-card:nth-child(5){grid-column:span 4}
.practice-card::before{
    content:"";
    position:absolute;
    top:0;
    right:0;
    width:0;
    height:2px;
    background:var(--accent);
    transition:width 0.5s var(--ease);
}
.practice-card:hover{background:var(--surface-alt)}
.practice-card:hover::before{width:100%}
.practice-number{
    font-family:var(--ff-display);
    font-size:0.85rem;
    color:var(--accent);
    letter-spacing:0.15em;
    margin-bottom:1.5rem;
    display:block;
}
.practice-card h3{
    font-size:1.55rem;
    font-weight:500;
    margin-bottom:1rem;
}
.practice-card p{
    color:var(--ink-2);
    font-size:0.98rem;
    line-height:1.7;
    margin-bottom:1.5rem;
}
.practice-card .practice-link{
    display:inline-flex;
    align-items:center;
    gap:0.5rem;
    font-size:0.85rem;
    font-weight:600;
    color:var(--ink);
    text-transform:uppercase;
    letter-spacing:0.1em;
}
.practice-card .practice-link::after{
    content:"←";
    transition:transform 0.35s var(--ease);
    color:var(--accent);
}
.practice-card:hover .practice-link::after{transform:translateX(-6px)}
@media (max-width:900px){
    .practice-card,
    .practice-card:nth-child(1),
    .practice-card:nth-child(2),
    .practice-card:nth-child(3),
    .practice-card:nth-child(4),
    .practice-card:nth-child(5){grid-column:span 12}
}

/* ------------------------------------------------------------------
   Attorney / About teaser
   ------------------------------------------------------------------ */
.attorney-split{
    display:grid;
    grid-template-columns:5fr 7fr;
    gap:clamp(2.5rem, 5vw, 5rem);
    align-items:center;
}
.attorney-img{
    position:relative;
    aspect-ratio:4/5;
    background:var(--border);
    overflow:hidden;
}
.attorney-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 20%;
    filter:saturate(1.05) contrast(1.02);
    transition:transform 0.8s var(--ease);
}
.attorney-img:hover img{transform:scale(1.03)}
.attorney-img::after{
    content:"";
    position:absolute;
    inset:1rem;
    border:1px solid rgba(213,190,148,0.6);
    pointer-events:none;
    transition:inset 0.5s var(--ease);
}
.attorney-img:hover::after{inset:0.5rem}
.attorney-copy h2{margin-bottom:1rem}
.attorney-copy .signature{
    font-family:var(--ff-display);
    font-style:italic;
    font-size:1.35rem;
    color:var(--accent);
    margin-top:2rem;
    font-weight:500;
}
.attorney-credentials{
    margin-top:2rem;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1.5rem;
    padding-top:1.5rem;
    border-top:1px solid var(--border);
}
.credential{
    font-size:0.9rem;
    color:var(--ink-2);
}
.credential-label{
    display:block;
    font-size:0.75rem;
    text-transform:uppercase;
    letter-spacing:0.18em;
    color:var(--accent);
    margin-bottom:0.4rem;
    font-weight:600;
}
@media (max-width:900px){
    .attorney-split{grid-template-columns:1fr;gap:2rem}
    .attorney-img{max-width:420px;margin-inline:auto}
}

/* ------------------------------------------------------------------
   Articles / thought leadership
   ------------------------------------------------------------------ */
.articles-list{
    list-style:none;
    display:flex;
    flex-direction:column;
}
.article-item{
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:2rem;
    align-items:center;
    padding:1.75rem 0;
    border-bottom:1px solid var(--border);
    transition:background 0.3s var(--ease), padding 0.3s var(--ease);
}
.article-item:hover{
    background:linear-gradient(270deg, transparent, var(--bg-2), transparent);
    padding-inline:1.5rem;
}
.article-number{
    font-family:var(--ff-display);
    font-size:1rem;
    color:var(--accent);
    min-width:2rem;
    letter-spacing:0.1em;
}
.article-title{
    font-family:var(--ff-display);
    font-size:clamp(1.15rem, 1.2vw + 0.6rem, 1.55rem);
    font-weight:500;
    color:var(--ink);
    line-height:1.3;
    transition:color 0.3s var(--ease);
}
.article-item:hover .article-title{color:var(--accent-dark)}
.article-meta{
    font-size:0.8rem;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:0.15em;
    white-space:nowrap;
}
@media (max-width:720px){
    .article-item{grid-template-columns:auto 1fr;gap:1rem}
    .article-meta{grid-column:2/3;justify-self:start}
}

/* ------------------------------------------------------------------
   Media mentions
   ------------------------------------------------------------------ */
.media-band{
    background:var(--bg-2);
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
}
.media-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:2rem;
}
.media-item{
    padding:2rem;
    background:var(--surface);
    border:1px solid var(--border);
    transition:all 0.4s var(--ease);
}
.media-item:hover{
    background:var(--surface-alt);
    border-color:var(--border-strong);
    transform:translateY(-4px);
    box-shadow:var(--shadow-md);
}
.media-outlet{
    font-family:var(--ff-display);
    font-size:1.05rem;
    font-weight:500;
    color:var(--accent);
    margin-bottom:0.5rem;
}
.media-headline{
    font-family:var(--ff-display);
    font-size:1.05rem;
    color:var(--ink);
    line-height:1.4;
    margin-bottom:1rem;
    font-weight:500;
}
.media-type{
    font-size:0.75rem;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:0.2em;
    border-top:1px solid var(--border);
    padding-top:1rem;
    display:block;
}
@media (max-width:1024px){.media-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.media-grid{grid-template-columns:1fr}}

/* ------------------------------------------------------------------
   Testimonials
   ------------------------------------------------------------------ */
.testimonials-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
}
.testimonial{
    background:var(--surface);
    border:1px solid var(--border);
    padding:2rem;
    position:relative;
    transition:all 0.4s var(--ease);
}
.testimonial:hover{
    border-color:var(--accent);
    box-shadow:var(--shadow-md);
    transform:translateY(-3px);
}
.testimonial::before{
    content:"";
    display:block;
    font-family:var(--ff-display);
    font-size:3rem;
    color:var(--accent);
    line-height:0.8;
    margin-bottom:0.5rem;
    opacity:0.6;
}
.testimonial-quote{
    font-family:var(--ff-display);
    font-size:1.05rem;
    color:var(--ink);
    line-height:1.55;
    margin-bottom:1.5rem;
    font-weight:400;
}
.testimonial-author{
    font-size:0.85rem;
    color:var(--ink-2);
    font-weight:600;
    padding-top:1rem;
    border-top:1px solid var(--border);
}
.testimonial-stars{
    color:var(--accent);
    letter-spacing:0.15em;
    font-size:0.9rem;
    margin-bottom:0.5rem;
}
@media (max-width:900px){.testimonials-grid{grid-template-columns:1fr}}

/* ------------------------------------------------------------------
   CTA band
   ------------------------------------------------------------------ */
.cta-band{
    background:var(--dark-surface);
    color:#F7F1E3;
    position:relative;
    overflow:hidden;
}
.cta-band::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(900px 500px at 85% 50%, rgba(169,132,86,0.22), transparent 65%);
    pointer-events:none;
}
.cta-content{
    position:relative;
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:3rem;
    align-items:center;
}
.cta-content h2{color:#FBF6EB;margin:0}
.cta-content p{color:rgba(247,241,227,0.78);margin-top:1rem;font-size:1.1rem}
.cta-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-self:start}
.cta-content .eyebrow{color:var(--accent-soft)}
.cta-content .eyebrow::before{background:var(--accent-soft)}
@media (max-width:900px){.cta-content{grid-template-columns:1fr}}

/* ------------------------------------------------------------------
   Forms
   ------------------------------------------------------------------ */
.form-card{
    background:var(--surface);
    border:1px solid var(--border);
    padding:clamp(2rem, 4vw, 3.5rem);
    box-shadow:var(--shadow-sm);
}
.form-row{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:1.25rem;
}
.form-group{margin-bottom:1.25rem}
.form-group--full{grid-column:1/-1}
.form-label{
    display:block;
    font-size:0.85rem;
    font-weight:600;
    color:var(--ink-2);
    margin-bottom:0.5rem;
    letter-spacing:0.02em;
}
.form-label .req{color:var(--oxblood)}
.form-input,
.form-select,
.form-textarea{
    width:100%;
    padding:0.95rem 1.1rem;
    background:var(--surface-alt);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    color:var(--ink);
    font-size:1rem;
    transition:border-color 0.3s var(--ease), box-shadow 0.3s var(--ease), background 0.3s var(--ease);
    font-family:inherit;
}
.form-textarea{min-height:140px;resize:vertical}
.form-input:focus,
.form-select:focus,
.form-textarea:focus{
    outline:0;
    border-color:var(--accent);
    box-shadow:0 0 0 3px var(--accent-glow);
    background:#fff;
}
.form-input::placeholder,
.form-textarea::placeholder{color:var(--muted-soft)}
.form-actions{
    display:flex;
    gap:1rem;
    align-items:center;
    justify-content:space-between;
    margin-top:1rem;
    flex-wrap:wrap;
}
.form-privacy{
    font-size:0.8rem;
    color:var(--muted);
    max-width:30ch;
}
.form-privacy a{color:var(--ink);border-bottom:1px solid var(--accent)}

@media (max-width:700px){
    .form-row{grid-template-columns:1fr}
}

/* Form feedback */
.form-message{
    margin-top:1.25rem;
    padding:1rem 1.25rem;
    border-right:3px solid var(--accent);
    background:var(--bg-2);
    font-size:0.95rem;
    opacity:0;
    transform:translateY(-6px);
    transition:opacity 0.35s var(--ease), transform 0.35s var(--ease);
    pointer-events:none;
    max-height:0;
    overflow:hidden;
    padding-block:0;
    margin-top:0;
}
.form-message.is-visible{
    opacity:1;
    transform:translateY(0);
    max-height:200px;
    padding-block:1rem;
    margin-top:1.25rem;
}
.form-message--success{
    border-right-color:#2F7D55;
    background:#EBF4EE;
    color:#1F5139;
}
.form-message--error{
    border-right-color:var(--oxblood);
    background:#F5E9EC;
    color:var(--oxblood);
}
.form-message-title{font-weight:700;margin-bottom:0.25rem}

/* Button loading state */
.btn.is-loading{position:relative;color:transparent;pointer-events:none}
.btn.is-loading::after{
    content:"";
    position:absolute;
    width:18px;
    height:18px;
    top:50%;
    left:50%;
    margin:-9px 0 0 -9px;
    border-radius:50%;
    border:2px solid currentColor;
    border-top-color:transparent;
    color:var(--surface);
    animation:btnSpin 0.75s linear infinite;
}
@keyframes btnSpin{to{transform:rotate(360deg)}}

/* ------------------------------------------------------------------
   Contact page
   ------------------------------------------------------------------ */
.contact-grid{
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:clamp(2rem, 5vw, 5rem);
    align-items:start;
}
.contact-info{
    padding-inline-start:0;
}
.contact-info h2{margin-bottom:1.5rem}
.contact-detail{
    padding:1.5rem 0;
    border-bottom:1px solid var(--border);
}
.contact-detail:first-of-type{padding-top:0}
.contact-detail:last-of-type{border-bottom:0}
.contact-label{
    font-size:0.75rem;
    text-transform:uppercase;
    letter-spacing:0.2em;
    color:var(--accent);
    font-weight:600;
    margin-bottom:0.5rem;
}
.contact-value{
    font-family:var(--ff-display);
    font-size:1.35rem;
    font-weight:500;
    color:var(--ink);
    line-height:1.4;
}
.contact-value a{color:var(--ink);border-bottom:1px solid transparent;transition:border-color 0.3s var(--ease)}
.contact-value a:hover{color:var(--ink);border-bottom-color:var(--accent)}
.contact-sub{font-size:0.9rem;color:var(--muted);margin-top:0.3rem}
.hours-list{list-style:none;font-size:0.95rem}
.hours-list li{
    display:flex;
    justify-content:space-between;
    padding:0.4rem 0;
    border-bottom:1px dashed var(--border);
}
.hours-list li:last-child{border-bottom:0}
.hours-list .day{color:var(--ink-2)}
.hours-list .hours{color:var(--ink);font-weight:500}

.social-links{
    display:flex;
    gap:0.75rem;
    flex-wrap:wrap;
    margin-top:0.75rem;
}
.social-link{
    width:42px;
    height:42px;
    border:1px solid var(--border-strong);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:var(--ink);
    font-size:0.9rem;
    font-weight:600;
    transition:all 0.3s var(--ease);
    border-radius:var(--radius-sm);
}
.social-link:hover{background:var(--ink);color:var(--surface);border-color:var(--ink)}

@media (max-width:900px){
    .contact-grid{grid-template-columns:1fr}
}

/* ------------------------------------------------------------------
   About page specifics
   ------------------------------------------------------------------ */
.bio-block{
    display:grid;
    grid-template-columns:1fr 2fr;
    gap:clamp(2rem, 5vw, 5rem);
    padding:5rem 0;
    border-bottom:1px solid var(--border);
}
.bio-block:last-child{border-bottom:0}
.bio-block .bio-label{
    font-family:var(--ff-display);
    font-size:0.9rem;
    color:var(--accent);
    letter-spacing:0.15em;
}
.bio-block h3{margin:0.5rem 0 0}
.bio-block p{font-size:1.05rem;line-height:1.85;margin-bottom:1rem}
.bio-block ul{list-style:none;margin-top:1rem}
.bio-block li{
    padding:0.75rem 0;
    padding-right:1.5rem;
    border-bottom:1px solid var(--border);
    position:relative;
}
.bio-block li::before{
    content:"";
    position:absolute;
    right:0;
    top:1.2rem;
    width:8px;
    height:1px;
    background:var(--accent);
}
.bio-block li:last-child{border-bottom:0}
@media (max-width:900px){
    .bio-block{grid-template-columns:1fr;gap:1rem}
}

.values-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.25rem;
}
.value-card{
    padding:2rem 1.75rem;
    background:var(--surface);
    border:1px solid var(--border);
    text-align:start;
    transition:all 0.4s var(--ease);
    position:relative;
}
.value-card::before{
    content:attr(data-num);
    font-family:var(--ff-display);
    font-size:0.85rem;
    color:var(--accent);
    letter-spacing:0.15em;
    display:block;
    margin-bottom:1rem;
}
.value-card h4{font-size:1.2rem;margin-bottom:0.5rem}
.value-card p{font-size:0.92rem;color:var(--ink-2);line-height:1.65;margin:0}
.value-card:hover{
    background:var(--surface-alt);
    border-color:var(--accent);
    transform:translateY(-4px);
    box-shadow:var(--shadow-md);
}
@media (max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.values-grid{grid-template-columns:1fr}}

/* ------------------------------------------------------------------
   FAQ — accordion
   ------------------------------------------------------------------ */
.faq-list{max-width:900px;margin:0 auto}
.faq-item{
    border-bottom:1px solid var(--border);
    padding:0;
}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-question{
    width:100%;
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:1.5rem;
    padding:1.75rem 0;
    text-align:start;
    font-family:var(--ff-display);
    font-size:clamp(1.05rem, 0.8vw + 0.6rem, 1.35rem);
    font-weight:500;
    color:var(--ink);
    cursor:pointer;
    transition:color 0.3s var(--ease);
}
.faq-question:hover{color:var(--accent-dark)}
.faq-num{
    font-size:0.85rem;
    color:var(--accent);
    letter-spacing:0.1em;
    padding-top:0.3rem;
}
.faq-icon{
    width:28px;
    height:28px;
    position:relative;
    flex-shrink:0;
    transition:transform 0.4s var(--ease);
}
.faq-icon::before,.faq-icon::after{
    content:"";
    position:absolute;
    background:var(--ink);
    transition:transform 0.4s var(--ease), background 0.3s var(--ease);
}
.faq-icon::before{
    top:50%;
    right:0;
    width:100%;
    height:1.5px;
    transform:translateY(-50%);
}
.faq-icon::after{
    top:0;
    right:50%;
    width:1.5px;
    height:100%;
    transform:translateX(50%);
}
.faq-item.is-open .faq-icon{transform:rotate(45deg)}
.faq-item.is-open .faq-icon::before,
.faq-item.is-open .faq-icon::after{background:var(--accent)}
.faq-answer{
    max-height:0;
    overflow:hidden;
    transition:max-height 0.5s var(--ease);
    padding-right:calc(1.5rem + 2rem);
}
.faq-answer-inner{
    padding-bottom:1.75rem;
    font-size:1rem;
    color:var(--ink-2);
    line-height:1.75;
}
.faq-item.is-open .faq-answer{max-height:600px}

/* ------------------------------------------------------------------
   Service page — process / timeline
   ------------------------------------------------------------------ */
.process-list{
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:1.25rem;
    counter-reset:step;
}
.process-step{
    padding:2rem 1.5rem;
    background:var(--surface);
    border:1px solid var(--border);
    position:relative;
    transition:all 0.4s var(--ease);
}
.process-step::before{
    counter-increment:step;
    content:"0" counter(step);
    display:block;
    font-family:var(--ff-display);
    font-size:1.4rem;
    color:var(--accent);
    margin-bottom:1rem;
    letter-spacing:0.05em;
}
.process-step h4{font-size:1.15rem;margin-bottom:0.5rem}
.process-step p{font-size:0.92rem;line-height:1.65;margin:0;color:var(--ink-2)}
.process-step:hover{
    background:var(--surface-alt);
    border-color:var(--accent);
    transform:translateY(-3px);
    box-shadow:var(--shadow-md);
}
@media (max-width:900px){.process-list{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.process-list{grid-template-columns:1fr}}

/* ------------------------------------------------------------------
   Legal / Privacy text
   ------------------------------------------------------------------ */
.legal-content{
    max-width:820px;
    margin:0 auto;
}
.legal-content h2{
    font-size:1.45rem;
    margin-top:2.5rem;
    padding-bottom:0.5rem;
    border-bottom:1px solid var(--border);
}
.legal-content h2:first-child{margin-top:0}
.legal-content p{font-size:1rem;line-height:1.85;color:var(--ink-2)}
.legal-content ul{list-style:none;margin:1rem 0}
.legal-content li{
    padding:0.35rem 0;
    padding-right:1.25rem;
    position:relative;
}
.legal-content li::before{
    content:"";
    position:absolute;
    right:0;
    top:0.95rem;
    width:8px;
    height:1px;
    background:var(--accent);
}
.legal-meta{
    font-size:0.85rem;
    color:var(--muted);
    padding:1rem 0;
    border-top:1px solid var(--border);
    margin-top:2.5rem;
}

/* ------------------------------------------------------------------
   Footer
   ------------------------------------------------------------------ */
.site-footer{
    background:var(--dark-surface);
    color:rgba(247,241,227,0.75);
    padding:5rem 0 2rem;
    font-size:0.92rem;
    position:relative;
}
.site-footer::before{
    content:"";
    position:absolute;
    top:0;
    right:0;
    left:0;
    height:1px;
    background:linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity:0.5;
}
.footer-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr 1fr 1fr;
    gap:3rem;
    padding-bottom:3rem;
    border-bottom:1px solid rgba(169,132,86,0.22);
}
.footer-brand .brand-mark{border-color:var(--accent-soft);color:var(--accent-soft)}
.footer-brand .brand-name{color:#FBF6EB}
.footer-brand .brand-sub{color:var(--accent-soft)}
.footer-tag{
    margin-top:1.25rem;
    max-width:30ch;
    font-size:0.92rem;
    line-height:1.7;
}
.footer-col h5{
    font-family:var(--ff-body);
    font-size:0.8rem;
    text-transform:uppercase;
    letter-spacing:0.22em;
    color:var(--accent-soft);
    margin-bottom:1.25rem;
    font-weight:600;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:0.55rem}
.footer-col a{color:rgba(247,241,227,0.75);transition:color 0.3s var(--ease)}
.footer-col a:hover{color:var(--accent-soft)}
.footer-col .contact-line{display:block;margin-bottom:0.35rem;color:rgba(247,241,227,0.85)}

.footer-bottom{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding-top:2rem;
    gap:1.5rem;
    flex-wrap:wrap;
    font-size:0.82rem;
    color:rgba(247,241,227,0.55);
}
.footer-bottom a{color:rgba(247,241,227,0.7)}
.footer-bottom a:hover{color:var(--accent-soft)}

.footer-signature{
    margin:1.5rem 0 0;
    width:100%;
    text-align:center;
    font-size:0.75rem;
    color:rgba(247,241,227,0.55);
    letter-spacing:0.04em;
    padding-top:1.5rem;
    border-top:1px solid rgba(169,132,86,0.12);
}
.footer-signature a{
    color:rgba(247,241,227,0.7);
    text-decoration:underline;
    text-decoration-color:rgba(169,132,86,0.4);
    text-underline-offset:3px;
    transition:color 0.3s var(--ease);
}
.footer-signature a:hover{color:var(--accent-soft)}

@media (max-width:900px){
    .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media (max-width:500px){
    .footer-grid{grid-template-columns:1fr}
    .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ------------------------------------------------------------------
   Reveal animations (IntersectionObserver)
   ------------------------------------------------------------------ */
.reveal{
    opacity:0;
    transform:translateY(24px);
    transition:opacity 0.8s var(--ease), transform 0.8s var(--ease);
}
.reveal.is-revealed{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:0.08s}
.reveal.delay-2{transition-delay:0.16s}
.reveal.delay-3{transition-delay:0.24s}
.reveal.delay-4{transition-delay:0.32s}

@media (prefers-reduced-motion:reduce){
    .reveal{opacity:1;transform:none;transition:none}
    .hero-bg{background-attachment:scroll}
    *,*::before,*::after{animation:none !important;transition:none !important}
}

/* ------------------------------------------------------------------
   Multi-step container pattern (global safety rule)
   ------------------------------------------------------------------ */
.funnel-page,
.quote-step,
.wizard-step{display:none}
.funnel-page.active,
.quote-step.active,
.wizard-step.active{display:block}

/* ------------------------------------------------------------------
   Decorative horizontal rule
   ------------------------------------------------------------------ */
.rule-fancy{
    display:flex;
    align-items:center;
    gap:1rem;
    margin-block:3rem;
}
.rule-fancy::before,
.rule-fancy::after{
    content:"";
    flex:1;
    height:1px;
    background:var(--border);
}
.rule-fancy-mark{
    width:10px;
    height:10px;
    border:1px solid var(--accent);
    transform:rotate(45deg);
}

/* Mobile polish */
@media (max-width:600px){
    section{padding-block:3.5rem}
    .hero{min-height:580px;padding:7rem 0 3.5rem}
    .page-hero{min-height:380px;padding:6rem 0 2rem}
    .stat{padding:2rem 1.25rem}
}
