/* ============================================================
   Alarik McClure for Bentonville City Council
   Campaign Website Styles
   Color: #98b39d (sage green)
   ============================================================ */

/* ── Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=DM+Sans:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;background:#f4f1ec;color:#1a1a1a;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(152,179,157,0.5);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:#98b39d}

/* ── Selection ── */
::selection{background:#98b39d;color:#fff}

/* ── Header ── */
.site-header{position:fixed;top:0;left:0;right:0;height:64px;z-index:100;background:rgba(244,241,236,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(152,179,157,0.2);display:flex;align-items:center;padding:0 clamp(1.5rem,4vw,5rem);transition:box-shadow .3s ease}
.site-header.scrolled{box-shadow:0 2px 12px rgba(0,0,0,.06)}

/* Left: logo group — flex:1 pushes nav to center */
.site-header > div:first-child{flex:1}

/* Center: nav links — stays centered */
.header-nav{display:flex;gap:2rem;align-items:center;flex:none}
.header-nav a{font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:500;letter-spacing:.04em;color:#1a1a1a;transition:color .2s ease;padding:0}
.header-nav a:hover{color:#98b39d}

/* Right: language + menu — flex:1, pushed to right */
.site-header > div:last-child{flex:1;display:flex;justify-content:flex-end;align-items:center;gap:1rem}

.header-logo{font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;color:#1a1a1a;letter-spacing:.02em;display:block;cursor:pointer}
.header-sub{font-family:'Space Mono',monospace;font-size:.625rem;font-weight:400;text-transform:uppercase;letter-spacing:.08em;color:#98b39d}
.header-lang{font-family:'Space Mono',monospace;font-size:.75rem;font-weight:400;color:#98b39d;letter-spacing:.04em;padding:.375rem .5rem;border-radius:.25rem;transition:background-color .2s ease;display:flex;align-items:center}
.header-lang:hover{background-color:rgba(152,179,157,.1)}
.header-lang svg{color:#98b39d}
.header-mobile-btn{display:none;flex-direction:column;gap:4px;padding:.5rem;background:none;border:none;cursor:pointer}
.header-mobile-btn span{width:20px;height:2px;background:#1a1a1a;display:block}

/* ── Mobile Menu ── */
.mobile-menu{position:fixed;inset:0;z-index:200;background:#f4f1ec;display:none;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mobile-menu.open{display:flex}
.mobile-menu-close{position:absolute;top:1rem;right:1.5rem;background:none;border:none;font-size:1.5rem;color:#1a1a1a;cursor:pointer}
.mobile-menu a{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.5rem,5vw,2.25rem);font-weight:600;color:#1a1a1a}

/* ── Hero ── */
.hero{position:relative;width:100%;min-height:calc(100vh - 64px);margin-top:64px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#f4f1ec 0%,#e8ede9 50%,#f4f1ec 100%)}
.hero-content{position:relative;z-index:2;max-width:900px;padding:clamp(2rem,5vw,4rem);text-align:center}
.hero-motto{font-family:'Playfair Display',Georgia,serif;font-size:clamp(3rem,8vw,6rem);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:#1a1a1a}
.hero-motto strong{font-weight:800;color:#000000}
.hero-divider{width:80px;height:2px;background:#98b39d;margin:2rem auto 0}
.hero-tagline{font-family:'DM Sans',sans-serif;font-size:1.25rem;font-weight:400;color:rgba(26,26,26,.6);margin-top:1.5rem}
.hero-buttons{display:flex;flex-direction:row;gap:1rem;margin-top:3rem;justify-content:center;flex-wrap:wrap}
.btn-primary{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;padding:1rem 2rem;background:#98b39d;color:#fff;border-radius:.375rem;transition:all .2s ease;box-shadow:0 2px 8px rgba(152,179,157,.4);display:inline-block;text-align:center}
.btn-primary:hover{background:#7a9a80;transform:scale(1.02)}
.btn-secondary{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;padding:1rem 2rem;background:transparent;color:#1a1a1a;border:1.5px solid #1a1a1a;border-radius:.375rem;transition:all .2s ease;display:inline-block;text-align:center}
.btn-secondary:hover{background:#1a1a1a;color:#fff}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;animation:bounce 2s infinite ease-in-out}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── Sections ── */
.section{padding:clamp(4rem,8vw,8rem) clamp(1.5rem,4vw,5rem)}
.section-cream{background:#f4f1ec}
.section-dark{background:#1a1a1a;padding-bottom:clamp(6rem,12vw,12rem)}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-family:'Space Mono',monospace;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:#98b39d}
.section-headline{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2rem,4vw,3rem);font-weight:600;line-height:1.1;letter-spacing:-.01em;color:#1a1a1a;margin-top:1rem}
.section-headline-light{color:#fff}
.section-sub{font-family:'DM Sans',sans-serif;font-size:clamp(1.125rem,2vw,1.5rem);font-weight:500;color:rgba(26,26,26,.6);margin-top:.5rem}

/* ── About Grid ── */
.about-grid{display:grid;grid-template-columns:minmax(300px,1.2fr) 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.about-body{font-family:'DM Sans',sans-serif;font-size:1rem;color:#1a1a1a;margin-top:1.5rem;max-width:560px}
.about-body p{margin-bottom:1rem}
.about-body p:last-child{margin-bottom:0}
.about-contact{margin-top:2rem}
.about-contact-item{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;font-family:'DM Sans',sans-serif;font-size:.875rem;color:rgba(26,26,26,.6)}
.about-contact-dot{width:6px;height:6px;border-radius:50%;background:#98b39d;flex-shrink:0}
.about-photo{position:relative}
.about-photo img{width:100%;border-radius:.75rem;aspect-ratio:3/4;object-fit:cover}
.about-badge{position:absolute;bottom:-1rem;left:-1rem;background:#98b39d;color:#fff;padding:.5rem 1rem;border-radius:.375rem;font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:700}

/* ── Platform ── */
.platform-inner{max-width:800px;margin:0 auto}
.platform-header{text-align:center}
.platform-list{margin-top:3rem}
.platform-item{padding:2rem 0;border-bottom:1px solid rgba(255,255,255,.15);display:grid;grid-template-columns:80px 1fr;gap:1.5rem;align-items:start}
.platform-item:last-child{border-bottom:none}
.platform-num{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2rem,4vw,3rem);font-weight:600;color:#98b39d;opacity:.6;line-height:1.1}
.platform-title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:600;color:#fff;line-height:1.2;letter-spacing:-.01em}
.platform-subs{margin-top:1rem}
.platform-sub{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(255,255,255,.8);padding-left:1.25rem;position:relative;margin-bottom:0;line-height:1.6;list-style:none;border-bottom:1px solid rgba(255,255,255,.08)}
.platform-sub:last-child{border-bottom:none}
.platform-sub::before{content:'';position:absolute;left:0;top:1.55rem;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:#98b39d}
.platform-sub-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:.75rem 0;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;color:#fff;cursor:pointer;text-align:left;line-height:1.4}
.platform-sub-toggle:hover{color:#98b39d}
.platform-sub-toggle::after{content:'+';font-size:1.25rem;font-weight:300;margin-left:1rem;transition:transform .3s ease;flex-shrink:0}
.platform-sub-toggle[aria-expanded="true"]{color:#98b39d}
.platform-sub-toggle[aria-expanded="true"]::after{content:'\2212'}
.platform-sub-dropdown{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease,opacity .3s ease;opacity:0;color:rgba(255,255,255,.7);font-family:'DM Sans',sans-serif;font-size:.95rem;line-height:1.6;padding:0 .25rem}
.platform-sub-dropdown.open{max-height:500px;opacity:1;padding:.25rem .25rem 1rem}

/* ── Contact (Homepage) ── */
.about-contact-large{margin-top:2.5rem}
.about-contact-large .about-contact-item{font-size:clamp(1.125rem,2vw,1.5rem);margin-bottom:1rem;gap:1rem}
.about-contact-large .about-contact-dot{width:10px;height:10px}
.about-contact-large a{position:relative;transition:color .2s ease}
.about-contact-large a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:#98b39d;transition:width .3s ease}
.about-contact-large a:hover{color:#98b39d}
.about-contact-large a:hover::after{width:100%}
.contact-form-wrapper{background:#fff;border-radius:.75rem;padding:clamp(2rem,4vw,3rem);box-shadow:0 4px 24px rgba(0,0,0,.06)}

/* ── Contact ── */
.contact-inner{max-width:600px;margin:0 auto;text-align:center}
.contact-form{margin-top:2rem;text-align:left}
.contact-field{margin-bottom:1.5rem}
.contact-field label{display:block;font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:500;color:rgba(26,26,26,.6);margin-bottom:.5rem}
.contact-field input,.contact-field textarea{width:100%;padding:.75rem 1rem;font-family:'DM Sans',sans-serif;font-size:1rem;color:#1a1a1a;background:transparent;border:1.5px solid rgba(26,26,26,.15);border-radius:.375rem;outline:none;transition:border-color .2s ease}
.contact-field input:focus,.contact-field textarea:focus{border-color:#98b39d}
.contact-info-box{background:rgba(152,179,157,.08);border:1px solid rgba(152,179,157,.25);border-radius:.75rem;padding:2rem;margin-top:2rem;text-align:left}
.contact-info-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;font-family:'DM Sans',sans-serif;font-size:1rem;color:#1a1a1a}
.contact-info-item:last-child{margin-bottom:0}
.contact-info-icon{color:#98b39d;font-size:1.25rem;flex-shrink:0;width:24px;text-align:center}
.contact-success{background:rgba(152,179,157,.1);border:1px solid rgba(152,179,157,.3);border-radius:.75rem;padding:2rem;margin-top:2rem}

/* ── Footer ── */
.site-footer{background:#1a1a1a;border-top:2px solid #98b39d;padding:3rem clamp(1.5rem,4vw,5rem);text-align:center}
.footer-name{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:600;color:#fff;line-height:1.2}
.footer-sub{font-family:'DM Sans',sans-serif;font-size:.875rem;color:rgba(255,255,255,.6);margin-top:.5rem}
.footer-social{display:flex;justify-content:center;gap:1.5rem;margin-top:1.5rem}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(152,179,157,.2);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease}
.footer-social a:hover{background:#98b39d;border-color:#98b39d}
.footer-legal{margin-top:2rem}
.footer-paid{font-family:'Space Mono',monospace;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5)}
.footer-copy{font-family:'Space Mono',monospace;font-size:.75rem;color:rgba(255,255,255,.4);margin-top:.5rem}

/* ── Responsive ── */
@media(max-width:768px){
.header-nav{display:none}
.header-mobile-btn{display:flex}
.about-grid{grid-template-columns:1fr}
.hero-buttons{flex-direction:column;align-items:center}
.btn-primary,.btn-secondary{width:100%;max-width:300px}
.platform-item{grid-template-columns:60px 1fr}
}

/* ── Vote Button (prominent, high contrast) ── */
.btn-vote{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:700;padding:1rem 2.5rem;background:#e85d3e;color:#fff;border-radius:.5rem;transition:all .2s ease;box-shadow:0 4px 16px rgba(232,93,62,.5);display:inline-block;text-align:center;letter-spacing:.04em;text-transform:uppercase;animation:votePulse 2.5s infinite ease-in-out;border:2px solid #e85d3e}
.btn-vote:hover{background:#d44a2a;transform:scale(1.05);box-shadow:0 6px 24px rgba(232,93,62,.6);border-color:#d44a2a}
@keyframes votePulse{0%,100%{box-shadow:0 4px 16px rgba(232,93,62,.5)}50%{box-shadow:0 4px 28px rgba(232,93,62,.8)}}

/* Header vote nav link */
.header-nav .nav-vote{background:#e85d3e;color:#fff;padding:.5rem 1.25rem;border-radius:.375rem;font-weight:600;transition:all .2s ease;letter-spacing:.04em}
.header-nav .nav-vote:hover{background:#d44a2a;color:#fff;transform:scale(1.05)}

/* ── Voting Page ── */
.voting-hero{background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);min-height:auto;padding:clamp(6rem,12vw,10rem) clamp(1.5rem,4vw,5rem) clamp(3rem,6vw,5rem);margin-top:64px;text-align:center}
.voting-hero-label{font-family:'Space Mono',monospace;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:#e85d3e;margin-bottom:1rem}
.voting-hero h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.02em}
.voting-hero-sub{font-family:'DM Sans',sans-serif;font-size:clamp(1rem,2vw,1.35rem);color:rgba(255,255,255,.7);margin-top:1.25rem;max-width:700px;margin-left:auto;margin-right:auto}
.voting-hero-dates{font-family:'Space Mono',monospace;font-size:.875rem;color:#e85d3e;margin-top:1.5rem;font-weight:700}
.voting-section{padding:clamp(3rem,6vw,5rem) clamp(1.5rem,4vw,5rem)}
.voting-section-alt{background:#f4f1ec}
.voting-section-dark{background:#1a1a1a}
.voting-inner{max-width:1000px;margin:0 auto}
.voting-section h2{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:600;color:#1a1a1a;line-height:1.2;margin-bottom:2rem;letter-spacing:-.01em}
.voting-section-dark h2{color:#fff}
.voting-section h3{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600;color:#1a1a1a;margin-top:2.5rem;margin-bottom:1rem}
.voting-section-dark h3{color:#fff}
.voting-intro{font-family:'DM Sans',sans-serif;font-size:1.125rem;color:rgba(26,26,26,.75);max-width:720px;margin-bottom:2.5rem;line-height:1.7}
.voting-section-dark .voting-intro{color:rgba(255,255,255,.7)}
.voting-hours-box{background:rgba(152,179,157,.08);border:1px solid rgba(152,179,157,.25);border-radius:.75rem;padding:clamp(1.5rem,3vw,2.5rem);margin-bottom:2.5rem}
.voting-hours-box-dark{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15)}
.voting-hours-box h3{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;color:#1a1a1a;margin-top:0;margin-bottom:1.25rem}
.voting-hours-box-dark h3{color:#fff}
.voting-hours-list{list-style:none;padding:0;margin:0}
.voting-hours-list li{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(26,26,26,.8);padding:.5rem 0;display:flex;justify-content:space-between;max-width:500px;border-bottom:1px solid rgba(152,179,157,.15)}
.voting-hours-list li:last-child{border-bottom:none}
.voting-hours-box-dark .voting-hours-list li{color:rgba(255,255,255,.75);border-bottom-color:rgba(255,255,255,.1)}
.voting-hours-list li strong{color:#1a1a1a;font-weight:600}
.voting-hours-box-dark .voting-hours-list li strong{color:#fff}
.voting-table{width:100%;border-collapse:collapse;margin-top:1.5rem;font-family:'DM Sans',sans-serif;font-size:.9375rem}
.voting-table thead{display:none}
.voting-table tr{border-bottom:1px solid rgba(26,26,26,.1);transition:background .15s ease}
.voting-table tr:hover{background:rgba(152,179,157,.06)}
.voting-table td{padding:1rem .75rem;color:rgba(26,26,26,.8);vertical-align:top}
.voting-table td:first-child{font-weight:600;color:#1a1a1a;white-space:nowrap}
.voting-table-dark tr{border-bottom-color:rgba(255,255,255,.1)}
.voting-table-dark tr:hover{background:rgba(255,255,255,.04)}
.voting-table-dark td{color:rgba(255,255,255,.7)}
.voting-table-dark td:first-child{color:#fff}
.voting-table .highlight-row{background:rgba(232,93,62,.08)}
.voting-table .highlight-row:hover{background:rgba(232,93,62,.14)}
.voting-table-dark .highlight-row{background:rgba(232,93,62,.12)}
.voting-table-dark .highlight-row:hover{background:rgba(232,93,62,.18)}
.voting-deadline-box{background:rgba(232,93,62,.1);border:2px solid #e85d3e;border-radius:.75rem;padding:clamp(1.5rem,3vw,2.5rem);text-align:center;margin-top:2rem}
.voting-deadline-box p{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600;color:#1a1a1a;margin:0}
.voting-deadline-box .deadline-date{color:#e85d3e;font-family:'Space Mono',monospace;font-size:.875rem;font-weight:700;margin-top:.5rem;display:block}
.voting-mail-list{margin-top:1rem;padding-left:1.5rem;list-style:disc}
.voting-mail-list li{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(26,26,26,.75);margin-bottom:.5rem;line-height:1.6}
.voting-section-dark .voting-mail-list li{color:rgba(255,255,255,.7)}
.vote-nav-link{display:none}
@media(max-width:768px){
  .btn-vote{width:100%;max-width:320px;font-size:.9375rem;padding:.875rem 1.5rem}
  .header-nav .nav-vote{display:none}
  .vote-nav-link{display:block;font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.5rem,5vw,2.25rem);font-weight:600;color:#e85d3e}
}

/* ── Styled Contact Link ── */
.contact-link{font-family:'DM Sans',sans-serif;font-weight:600;color:#e85d3e;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px;transition:all .2s ease;padding:0 .2rem;border-radius:.25rem}
.contact-link:hover{color:#fff;background:#e85d3e;text-decoration:none;padding:.2rem .5rem}

/* ── Tripartite Motto ── */
.motto-triptych{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.5rem);margin-top:2.5rem;text-align:left}
.motto-pillar{background:rgba(255,255,255,.7);border-radius:.75rem;padding:clamp(1.5rem,3vw,2rem);border:1px solid rgba(152,179,157,.25);transition:all .25s ease}
.motto-pillar:hover{background:#fff;border-color:rgba(152,179,157,.5);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.motto-num{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2rem,4vw,2.5rem);font-weight:600;color:#98b39d;opacity:.5;line-height:1;display:block;margin-bottom:.75rem}
.motto-title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.125rem,2vw,1.35rem);font-weight:600;color:#1a1a1a;line-height:1.2;margin:0}
.motto-desc{font-family:'DM Sans',sans-serif;font-size:.9375rem;color:rgba(26,26,26,.65);margin-top:.75rem;line-height:1.6}
@media(max-width:768px){
  .motto-triptych{grid-template-columns:1fr;text-align:center}
  .motto-num{font-size:2.5rem}
}

/* ── Projects Page ── */
.projects-block{margin-bottom:3rem}
.projects-block:last-child{margin-bottom:0}
.projects-intro{font-family:'DM Sans',sans-serif;font-size:clamp(1.125rem,2.5vw,1.35rem);font-weight:500;color:#1a1a1a;line-height:1.6;margin-bottom:2rem;max-width:720px}
.projects-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.projects-card-grid-cond{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-width:600px}
.project-card-item{background:#fff;border-radius:.75rem;padding:2rem;border:1px solid rgba(152,179,157,.2);transition:all .25s ease;position:relative;display:flex;flex-direction:column;cursor:pointer;text-decoration:none;color:inherit}
.project-card-item:hover{background:#98b39d;border-color:#98b39d;transform:translateY(-6px);box-shadow:0 12px 32px rgba(152,179,157,.35)}
.project-card-item:hover h3{color:#fff}
.project-card-item:hover p{color:rgba(255,255,255,.85)}
.project-card-item:hover .project-card-num{color:rgba(255,255,255,.5)}
.project-card-item:hover .project-card-arrow{color:#fff;transform:translateX(4px)}
.project-card-num{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:600;color:#98b39d;opacity:.4;line-height:1;margin-bottom:.75rem;transition:color .25s ease}
.project-card-item h3{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;color:#1a1a1a;line-height:1.2;margin:0;transition:color .25s ease}
.project-card-item p{font-family:'DM Sans',sans-serif;font-size:.9375rem;color:rgba(26,26,26,.6);margin-top:.75rem;line-height:1.6;flex:1;transition:color .25s ease}
.project-card-arrow{font-family:'DM Sans',sans-serif;font-size:1.5rem;color:#98b39d;margin-top:1.5rem;align-self:flex-end;transition:all .25s ease}
.project-card-placeholder{background:rgba(152,179,157,.06);border-style:dashed;border-color:rgba(152,179,157,.3);cursor:default}
.project-card-placeholder:hover{background:rgba(152,179,157,.1);border-color:rgba(152,179,157,.4);transform:none;box-shadow:none}
.project-card-placeholder:hover h3{color:#1a1a1a}
.project-card-placeholder:hover p{color:rgba(26,26,26,.6)}
.project-card-placeholder:hover .project-card-num{color:#98b39d}
.project-card-placeholder h3{color:rgba(26,26,26,.45)}
.project-card-placeholder p{color:rgba(26,26,26,.35)}
.projects-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(152,179,157,.5),transparent);margin:2.5rem 0}
@media(max-width:768px){
  .projects-card-grid{grid-template-columns:1fr}
  .projects-card-grid-cond{grid-template-columns:1fr;max-width:none}
}
.projects-hero{background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);min-height:auto;padding:clamp(6rem,12vw,10rem) clamp(1.5rem,4vw,5rem) clamp(3rem,6vw,5rem);margin-top:64px;text-align:center}
.projects-hero-label{font-family:'Space Mono',monospace;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:#98b39d;margin-bottom:1rem}
.projects-hero h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.02em}
.projects-hero-sub{font-family:'DM Sans',sans-serif;font-size:clamp(1rem,2vw,1.35rem);color:rgba(255,255,255,.7);margin-top:1.25rem;max-width:700px;margin-left:auto;margin-right:auto}
.projects-section{padding:clamp(3rem,6vw,5rem) clamp(1.5rem,4vw,5rem);background:#f4f1ec}
.projects-inner{max-width:1000px;margin:0 auto}
.project-row{display:grid;grid-template-columns:120px 1fr;gap:clamp(1.5rem,3vw,2.5rem);padding:2.5rem 0;border-bottom:1px solid rgba(26,26,26,.1);transition:background .15s ease}
.project-row:last-child{border-bottom:none}
.project-row:hover{background:rgba(152,179,157,.06);margin:0 -1.5rem;padding:2.5rem 1.5rem;border-radius:.5rem}
.project-meta{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}
.project-num{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.75rem,3vw,2.5rem);font-weight:600;color:#98b39d;opacity:.5;line-height:1}
.project-tag{font-family:'Space Mono',monospace;font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#98b39d;background:rgba(152,179,157,.12);padding:.25rem .5rem;border-radius:.25rem}
.project-body h2{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600;color:#1a1a1a;line-height:1.2;margin:0}
.project-body h2 a{color:inherit;transition:color .2s ease}
.project-body h2 a:hover{color:#98b39d}
.project-body p{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(26,26,26,.65);margin-top:.75rem;line-height:1.7;max-width:640px}
@media(max-width:768px){
  .project-row{grid-template-columns:1fr;gap:1rem}
  .project-row:hover{margin:0;padding:2.5rem 0;background:transparent}
  .project-meta{flex-direction:row;align-items:center;gap:1rem}
}

/* ── Entrance Animation ── */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s cubic-bezier(.25,.1,.25,1),transform .6s cubic-bezier(.25,.1,.25,1)}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ── FAQ Page ── */
.faq-list{margin-top:2.5rem}
.faq-item{border-bottom:1px solid rgba(26,26,26,.1)}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;background:none;border:none;cursor:pointer;text-align:left;gap:1rem}
.faq-question span:first-child{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.125rem,2vw,1.35rem);font-weight:600;color:#1a1a1a;line-height:1.3;flex:1}
.faq-icon{font-family:'DM Sans',sans-serif;font-size:1.5rem;font-weight:300;color:#98b39d;transition:transform .3s ease;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(152,179,157,.1)}
.faq-question:hover .faq-icon{background:rgba(152,179,157,.2)}
.faq-question.active .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;padding:0}
.faq-answer p{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(26,26,26,.75);line-height:1.7;padding-bottom:1.5rem;max-width:720px}
.faq-question[aria-expanded="true"] + .faq-answer{max-height:500px}

