@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg-dark:#1A1A1F;--text-on-dark:#F4F0EA;--bg-light:#F4F0EA;--text-on-light:#1A1A1F;--bg-accent:#B87333;--text-on-accent:#1A1A1F;--bg-steel:#6E7580;--text-on-steel:#F4F0EA;--copper:#B87333;--charcoal:#1A1A1F;--radius:2px;--shadow:0 14px 44px rgba(26,26,31,.14)}
html{scroll-behavior:smooth}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;line-height:1.65;font-size:1.05rem;background:var(--bg-light);color:var(--text-on-light);overflow-x:hidden}
h1,h2,h3,h4{font-family:'DM Serif Display',Georgia,serif;line-height:1.15;font-weight:400}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
.surface-dark{background:var(--bg-dark);color:var(--text-on-dark)}
.surface-light{background:var(--bg-light);color:var(--text-on-light)}
.surface-accent{background:var(--bg-accent);color:var(--text-on-accent)}
.surface-steel{background:var(--bg-steel);color:var(--text-on-steel)}
.surface-dark a,.surface-light a,.surface-steel a{color:currentColor;text-decoration:underline}
.surface-dark *,.surface-light *,.surface-steel *,.surface-accent *{color:inherit}
.surface-light .bench-label,.surface-steel .bench-label{color:var(--copper);letter-spacing:.16em;text-transform:uppercase;font-size:.72rem;font-weight:700}
.surface-dark .bench-label{color:#D4956A}
.container{width:min(1140px,92vw);margin:0 auto}
.container-wide{width:min(1280px,94vw);margin:0 auto}
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s}
.site-header--sticky{background:var(--bg-light);color:var(--text-on-light);box-shadow:0 2px 16px rgba(26,26,31,.1)}
.site-header.is-scrolled{background:var(--bg-light);color:var(--text-on-light);box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.logo{font-family:'DM Serif Display',serif;font-size:1.35rem;text-decoration:none;color:inherit;font-weight:400}
.site-nav ul{display:flex;gap:1.4rem;list-style:none;flex-wrap:wrap}
.site-nav a{text-decoration:none;font-weight:600;font-size:.95rem;opacity:.88;color:inherit}
.site-nav a:hover,.site-nav a.is-active{opacity:1;text-decoration:underline;text-underline-offset:3px}
.nav-toggle{display:none;align-items:center;gap:.45rem;background:none;border:1px solid currentColor;padding:.45rem .7rem;border-radius:var(--radius);cursor:pointer;color:inherit;font:inherit;font-weight:600}
.nav-toggle-icon{display:flex;flex-direction:column;gap:5px;width:22px}
.nav-toggle-icon span{display:block;height:2px;background:currentColor;border-radius:1px}
.nav-backdrop{display:none}
.nav-close{display:none}
.hero-spotlight{min-height:88vh;min-height:88dvh;display:grid;grid-template-columns:1.2fr 1fr;align-items:center;padding-top:5rem;position:relative}
.hero-spotlight::after{content:'';position:absolute;right:calc(50% - 1px);top:15%;bottom:15%;width:3px;background:var(--copper);z-index:2}
.hero-spotlight-left{padding:clamp(2rem,5vw,4rem) clamp(1.25rem,4.5vw,3.5rem)}
.hero-spotlight-right{position:relative;height:100%;min-height:420px}
.hero-spotlight-right img{width:100%;height:100%;object-fit:cover;min-height:420px}
.hero-label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:.75rem;color:var(--copper)}
.hero-serial{font-size:.92rem;margin-bottom:1rem;opacity:.85;font-weight:500}
.hero-spotlight h1{font-size:clamp(2.2rem,4.8vw,3.75rem);margin-bottom:1rem;max-width:14ch}
.hero-sub{max-width:48ch;margin-bottom:1.75rem;font-size:1.08rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.trust-strip{font-size:.82rem;letter-spacing:.04em;opacity:.85;font-weight:500}
.btn{display:inline-block;padding:.82rem 1.55rem;font-weight:700;text-decoration:none;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;font-family:inherit;font-size:.95rem;transition:opacity .2s,box-shadow .2s;text-transform:uppercase;letter-spacing:.06em}
.btn:hover{opacity:.9;box-shadow:0 4px 16px rgba(26,26,31,.18)}
.btn-primary{background:var(--copper);color:var(--text-on-dark);border-color:var(--copper)}
.btn-outline{background:transparent;color:inherit;border-color:currentColor}
.btn-charcoal{background:var(--charcoal);color:var(--text-on-dark);border-color:var(--charcoal)}
.btn-dark{background:var(--charcoal);color:var(--text-on-dark);border-color:var(--charcoal)}
.btn-charcoal,.btn-dark,.btn-sage,.btn-primary{color:var(--text-on-dark)!important}
.cta-band.surface-accent .btn-charcoal,
.cta-band.surface-accent .btn-dark,
.surface-dark .btn-charcoal{color:var(--text-on-dark)!important}
section{padding:4.5rem 0}
.heat-band{height:4px;background:linear-gradient(90deg,var(--copper),var(--charcoal),var(--copper));margin:0}
.bench-charter{padding:3.5rem 0;text-align:center;border-bottom:1px solid rgba(26,26,31,.08)}
.bench-charter p{max-width:62ch;margin:0 auto;font-size:1.12rem}
.heat-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;text-align:center;border-top:3px solid var(--copper);border-bottom:3px solid var(--copper)}
.heat-stat{padding:2.25rem 1rem;border-right:1px solid rgba(244,240,234,.15)}
.heat-stat:last-child{border-right:none}
.heat-stat-num{font-family:'DM Serif Display',serif;font-size:2.6rem;display:block;line-height:1}
.heat-stat-label{font-size:.85rem;margin-top:.5rem;opacity:.9}
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem}
.spec-card{padding:1.75rem;border-left:4px solid var(--copper);background:var(--bg-light);color:var(--text-on-light);box-shadow:var(--shadow)}
.spec-card .line-tag{font-size:.68rem;letter-spacing:.14em;font-weight:700;color:var(--copper);margin-bottom:.4rem;text-transform:uppercase}
.spec-card h3{font-size:1.25rem;margin-bottom:.6rem}
.workshop-timeline{display:grid;gap:2rem;padding-left:2rem;border-left:3px solid var(--copper)}
.workshop-timeline-item{position:relative}
.workshop-timeline-item::before{content:'';position:absolute;left:-2.6rem;top:.35rem;width:14px;height:14px;background:var(--copper);border-radius:50%}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.preview-card{box-shadow:var(--shadow);overflow:hidden}
.preview-card.offset{margin-top:2.5rem}
.preview-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.preview-card figcaption{padding:1rem;font-size:.88rem;font-weight:600}
.faq-two-col{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem 3rem}
.faq-col h3{font-size:1.08rem;margin-bottom:.45rem;font-family:'IBM Plex Sans',sans-serif;font-weight:700}
.faq-col p{margin-bottom:1.4rem;font-size:.97rem}
.faq-img img{width:100%;max-height:380px;object-fit:cover;border-radius:var(--radius)}
.cta-band{text-align:center;padding:4rem 2rem;border-top:4px solid var(--copper)}
.cta-band h2{font-size:clamp(1.75rem,3vw,2.35rem);margin-bottom:1rem}
.page-hero{padding:6rem 0 3rem}
.page-hero h1{font-size:clamp(2rem,4vw,2.85rem)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.content-img{border-radius:var(--radius);box-shadow:var(--shadow)}
.program-list article{margin-bottom:3.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(26,26,31,.1)}
.program-list h2{font-size:1.55rem;margin-bottom:.5rem}
.price-tag{color:var(--copper);font-weight:700;margin:.75rem 0;font-size:1.05rem}
.service-row{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid rgba(26,26,31,.08)}
.service-row.reverse{direction:rtl}
.service-row.reverse>*{direction:ltr}
.about-hero-full{min-height:55vh;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end}
.about-hero-full::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,31,.88),transparent 60%)}
.about-hero-full .container{position:relative;z-index:2;padding-bottom:3rem}
.diag-spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.diag-spec{padding:1.5rem;border:2px solid rgba(184,115,51,.35);transform:rotate(-.8deg)}
.diag-spec:nth-child(2){transform:rotate(.6deg);margin-top:1.25rem}
.contact-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:3rem}
.form-panel{background:var(--bg-light);color:var(--text-on-light);padding:2rem;border:1px solid rgba(26,26,31,.1);box-shadow:var(--shadow)}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.92rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.7rem .85rem;border:1px solid rgba(26,26,31,.2);border-radius:var(--radius);font:inherit;background:#fff;color:var(--charcoal)}
.form-group textarea{min-height:140px;resize:vertical}
.form-check{display:flex;gap:.65rem;align-items:flex-start;font-size:.92rem}
.form-check input{margin-top:.25rem}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.alert{padding:1rem;margin-bottom:1.25rem;border-left:4px solid var(--copper);background:rgba(184,115,51,.08)}
.legal-content h2{font-size:1.35rem;margin:2rem 0 1rem;font-family:'IBM Plex Sans',sans-serif;font-weight:700}
.legal-content p,.legal-content li{margin-bottom:1rem}
.legal-content ul{padding-left:1.5rem;margin-bottom:1rem}
.site-footer{padding:3.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:2rem}
.footer-grid h3{font-family:'IBM Plex Sans',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.08em}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:.45rem}
.footer-grid a{text-decoration:none;opacity:.88}
.footer-grid a:hover{opacity:1;text-decoration:underline}
.footer-bottom{border-top:1px solid rgba(244,240,234,.15);padding-top:1.5rem;font-size:.88rem;opacity:.9}
.footer-disclaimer{font-size:.82rem;margin-top:1rem;opacity:.85;max-width:72ch}
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;padding:1.25rem;box-shadow:0 -8px 32px rgba(26,26,31,.2)}
.cookie-inner{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto}
.cookie-actions{display:flex;flex-wrap:wrap;gap:.65rem}
.cookie-custom-panel{width:100%;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(26,26,31,.12)}
.error-page{min-height:70vh;display:flex;align-items:center;text-align:center;padding:6rem 1rem}
.error-page h1{font-size:clamp(1.75rem,4vw,2.5rem);margin-bottom:1rem}
.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.js .reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}
@media(max-width:900px){
  .hero-spotlight{grid-template-columns:1fr;min-height:70vh}
  .hero-spotlight::after{display:none}
  .hero-spotlight-right{min-height:280px}
  .heat-stats,.spec-grid,.preview-grid,.faq-two-col,.grid-2,.contact-grid,.footer-grid,.service-row,.diag-spec-grid{grid-template-columns:1fr}
  .heat-stat{border-right:none;border-bottom:1px solid rgba(244,240,234,.12)}
  .preview-card.offset{margin-top:0}
  .nav-toggle{display:flex}
  .site-nav{position:fixed;top:0;right:0;width:min(320px,88vw);height:100vh;background:linear-gradient(to bottom,rgba(244,240,234,.15) 0%,var(--bg-light) 130px),url('/images/roastcraft-05-hamilton-street-contact.jpg') top center/100% 120px no-repeat,var(--bg-light);color:var(--text-on-light);padding:8.25rem 1.5rem 2rem;transform:translateX(100%);transition:transform .3s;box-shadow:var(--shadow);z-index:150}
  .site-nav.is-open{transform:translateX(0)}
  .site-nav ul{flex-direction:column;gap:1.2rem}
  .nav-close{display:block;position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.75rem;cursor:pointer;color:inherit}
  .nav-backdrop{position:fixed;inset:0;background:rgba(26,26,31,.5);z-index:140}
  .nav-backdrop.is-visible{display:block}
  body.nav-open{overflow:hidden}
}
