:root{
  --ink:#2b2b28;
  --ink-soft:#6b6b64;
  --cream:#faf8f4;
  --paper:#ffffff;
  --sand:#e9e2d6;
  --gold:#a8895a;
  --gold-dark:#8a6f45;
  --line:#e3ddd2;
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ===== Header ===== */
header.site{position:sticky;top:0;z-index:50;background:rgba(250,248,244,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{max-width:1280px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{width:44px;height:44px;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;letter-spacing:1px;color:var(--gold-dark);flex-shrink:0}
.logo-text{font-family:var(--serif);font-size:20px;letter-spacing:.5px}
.logo-text small{display:block;font-family:var(--sans);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
nav.main{display:flex;gap:28px;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:500}
nav.main a{color:var(--ink-soft);transition:color .2s;padding:4px 0;border-bottom:1px solid transparent}
nav.main a:hover,nav.main a.active{color:var(--ink);border-bottom-color:var(--gold)}
@media(max-width:860px){
  nav.main{gap:16px;font-size:11px;flex-wrap:wrap;justify-content:flex-end}
  .logo-text{font-size:16px}
  .logo-text small{font-size:8px;letter-spacing:2px}
}

/* ===== Hero ===== */
.hero{background:linear-gradient(135deg,#3a3631 0%,#56504a 55%,#6e6358 100%);color:#f5f1e9;text-align:center;padding:90px 24px 100px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 70% 20%, rgba(168,137,90,.25), transparent 55%)}
.hero > *{position:relative;z-index:1}
.hero .eyebrow{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:#d8c8aa;margin-bottom:16px}
.hero h1{font-family:var(--serif);font-size:clamp(30px,4.5vw,54px);font-weight:500;max-width:800px;margin:0 auto 18px;line-height:1.25}
.hero p{max-width:640px;margin:0 auto;color:#d9d4ca;font-size:15.5px}
.hero .cta-row{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;padding:13px 36px;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;transition:all .25s;cursor:pointer;border:1px solid transparent}
.btn-outline-light{border-color:#d8c8aa;color:#f0e8d8;background:transparent}
.btn-outline-light:hover{background:#d8c8aa;color:#3a3631}
.btn-solid-light{background:#d8c8aa;color:#3a3631;border-color:#d8c8aa}
.btn-solid-light:hover{background:#f0e8d8}
.btn-dark{background:var(--ink);color:#f5f1e9}
.btn-dark:hover{background:var(--gold-dark)}
.btn-outline{border-color:var(--gold);color:var(--gold-dark)}
.btn-outline:hover{background:var(--gold);color:#fff}
.hero.compact{padding:60px 24px 64px}

/* ===== Sections ===== */
.section{max-width:1280px;margin:0 auto;padding:72px 32px}
.section-head{text-align:center;max-width:680px;margin:0 auto 48px}
.section-head .eyebrow{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold-dark);margin-bottom:12px}
.section-head h2{font-family:var(--serif);font-size:clamp(26px,3.2vw,38px);font-weight:500;margin-bottom:14px;line-height:1.3}
.section-head p{color:var(--ink-soft);font-size:14.5px}
.section.tinted{max-width:none;background:#f2eee6}
.section.tinted .section-inner{max-width:1280px;margin:0 auto}

/* Cards / features */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px}
.feature{background:var(--paper);border:1px solid var(--line);padding:32px 28px;transition:all .25s}
.feature:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(60,52,38,.1)}
.feature .num{font-family:var(--serif);font-size:30px;color:var(--gold);margin-bottom:12px}
.feature h3{font-family:var(--serif);font-size:19px;font-weight:500;margin-bottom:10px}
.feature p{font-size:13.5px;color:var(--ink-soft)}

/* Category tiles (home) */
.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:22px}
.tile{position:relative;aspect-ratio:4/3;display:flex;align-items:flex-end;padding:18px;color:#fff;overflow:hidden;transition:all .25s}
.tile:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(60,52,38,.18)}
.tile svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-65%);width:54px;height:54px;stroke:rgba(255,255,255,.85);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.tile span{position:relative;font-family:var(--serif);font-size:16.5px;letter-spacing:.5px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:32px;text-align:center}
.stats .stat b{display:block;font-family:var(--serif);font-size:44px;font-weight:500;color:var(--gold-dark);line-height:1.1}
.stats .stat span{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft)}

/* Steps (process) */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:26px;counter-reset:step}
.step{position:relative;padding:28px 24px;background:var(--paper);border:1px solid var(--line)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--serif);font-size:26px;color:var(--gold);display:block;margin-bottom:10px}
.step h4{font-family:var(--serif);font-size:17px;font-weight:500;margin-bottom:8px}
.step p{font-size:13px;color:var(--ink-soft)}

/* Two-column */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media(max-width:860px){.two-col{grid-template-columns:1fr;gap:32px}}
.two-col h2{font-family:var(--serif);font-size:clamp(24px,3vw,34px);font-weight:500;margin-bottom:16px;line-height:1.3}
.two-col p{color:var(--ink-soft);font-size:14.5px;margin-bottom:14px}
.img-block{aspect-ratio:4/3;background:linear-gradient(145deg,#9c8a72,#b3a188);display:flex;align-items:center;justify-content:center;position:relative}
.img-block svg{width:80px;height:80px;stroke:rgba(255,255,255,.9);fill:none;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round}
.img-block .ph-label{position:absolute;bottom:12px;right:14px;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,#3a3631,#56504a);color:#f5f1e9;text-align:center;padding:64px 24px}
.cta-band h2{font-family:var(--serif);font-size:clamp(24px,3vw,36px);font-weight:500;margin-bottom:14px}
.cta-band p{color:#d9d4ca;max-width:560px;margin:0 auto 28px;font-size:14.5px}

/* Checklist */
.checklist{list-style:none}
.checklist li{padding:10px 0 10px 30px;position:relative;font-size:14px;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.checklist li::before{content:"";position:absolute;left:2px;top:16px;width:14px;height:8px;border-left:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(-45deg)}

/* ===== Catalogue ===== */
.catalogue{max-width:1280px;margin:0 auto;padding:48px 32px 80px;display:grid;grid-template-columns:230px 1fr;gap:48px}
@media(max-width:860px){.catalogue{grid-template-columns:1fr;gap:24px}}
.sidebar h3{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.cat-list{list-style:none}
.cat-list li{margin-bottom:2px}
.cat-list button{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:13.5px;color:var(--ink-soft);padding:7px 10px;border-left:2px solid transparent;transition:all .15s;display:flex;justify-content:space-between;align-items:center}
.cat-list button:hover{color:var(--ink);background:#f2eee6}
.cat-list button.active{color:var(--gold-dark);border-left-color:var(--gold);background:#f4efe5;font-weight:600}
.cat-list .count{font-size:11px;color:#b3ab9c}
@media(max-width:860px){
  .cat-list{display:flex;flex-wrap:wrap;gap:8px}
  .cat-list button{border:1px solid var(--line);border-radius:20px;padding:6px 14px;font-size:12.5px}
  .cat-list button.active{border-color:var(--gold)}
  .cat-list .count{display:none}
}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.result-info{font-size:13px;color:var(--ink-soft)}
.result-info strong{color:var(--ink)}
.controls{display:flex;gap:12px;flex-wrap:wrap}
.controls input,.controls select{font-family:var(--sans);font-size:13px;padding:9px 14px;border:1px solid var(--line);background:var(--paper);color:var(--ink);outline:none;border-radius:2px}
.controls input{width:210px}
.controls input:focus,.controls select:focus{border-color:var(--gold)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:26px}
.card{background:var(--paper);border:1px solid var(--line);cursor:pointer;transition:all .25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(60,52,38,.12);border-color:var(--sand)}
.card-img{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card-img svg{width:64px;height:64px;stroke:rgba(255,255,255,.92);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.card-img .ph-label{position:absolute;bottom:10px;right:12px;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55)}
.card-body{padding:16px 18px 18px}
.card-body .cat{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-dark);margin-bottom:5px}
.card-body h4{font-family:var(--serif);font-size:17px;font-weight:500;margin-bottom:6px}
.card-body p{font-size:12.5px;color:var(--ink-soft);line-height:1.5}
.empty{grid-column:1/-1;text-align:center;padding:70px 20px;color:var(--ink-soft);font-size:14px}

/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(35,31,26,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--paper);max-width:740px;width:100%;display:grid;grid-template-columns:300px 1fr;overflow:hidden;position:relative;max-height:90vh}
@media(max-width:680px){.modal{grid-template-columns:1fr;overflow-y:auto}}
.modal-img{display:flex;align-items:center;justify-content:center;min-height:300px}
.modal-img svg{width:90px;height:90px;stroke:rgba(255,255,255,.92);fill:none;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round}
.modal-body{padding:34px 36px;overflow-y:auto}
.modal-body .cat{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-dark)}
.modal-body h3{font-family:var(--serif);font-size:26px;font-weight:500;margin:8px 0 14px}
.modal-body p{font-size:13.5px;color:var(--ink-soft);margin-bottom:18px}
.spec{font-size:13px;border-top:1px solid var(--line)}
.spec div{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line)}
.spec span:first-child{color:var(--ink-soft)}
.modal-body .inquiry{display:inline-block;margin-top:22px;padding:11px 28px;background:var(--ink);color:#f5f1e9;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;border:none;cursor:pointer;transition:background .2s}
.modal-body .inquiry:hover{background:var(--gold-dark)}
.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:26px;line-height:1;cursor:pointer;color:var(--ink-soft);z-index:2}
.modal-close:hover{color:var(--ink)}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:56px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-form label{display:block;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);margin:18px 0 6px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;font-family:var(--sans);font-size:14px;padding:12px 14px;border:1px solid var(--line);background:var(--paper);outline:none;border-radius:2px}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--gold)}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-info h3{font-family:var(--serif);font-size:20px;font-weight:500;margin-bottom:16px}
.contact-info .item{padding:14px 0;border-bottom:1px solid var(--line);font-size:14px}
.contact-info .item b{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-dark);font-weight:600;margin-bottom:3px}
.contact-info .item a:hover{color:var(--gold-dark)}

/* ===== Portfolio ===== */
.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px}
.project{background:var(--paper);border:1px solid var(--line);transition:all .25s;display:flex;flex-direction:column}
.project:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(60,52,38,.12)}
.project-img{aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;position:relative}
.project-img svg{width:64px;height:64px;stroke:rgba(255,255,255,.9);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.project-img .ph-label{position:absolute;bottom:10px;right:12px;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55)}
.project-body{padding:22px 24px 24px;flex:1}
.project-body .meta{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-dark);margin-bottom:6px}
.project-body h3{font-family:var(--serif);font-size:20px;font-weight:500;margin-bottom:8px}
.project-body p{font-size:13.5px;color:var(--ink-soft);margin-bottom:12px}
.project-body .scope{font-size:12px;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:12px}
.project-body .scope b{display:block;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-dark);font-weight:600;margin-bottom:4px}

/* ===== Policy / prose pages ===== */
.prose{max-width:780px;margin:0 auto;padding:56px 32px 80px}
.prose h2{font-family:var(--serif);font-size:24px;font-weight:500;margin:36px 0 14px}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{font-size:14.5px;color:var(--ink-soft);margin-bottom:12px}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose .updated{font-size:12.5px;color:#9b937f;margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.prose .notice{background:#f4efe5;border-left:3px solid var(--gold);padding:14px 18px;font-size:13px;color:var(--ink-soft);margin-bottom:28px}

/* ===== Footer ===== */
footer.site{background:#2e2b27;color:#bdb6aa;padding:56px 32px 32px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
@media(max-width:860px){.footer-inner{grid-template-columns:1fr 1fr}}
footer.site h5{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:#e8dfcf;margin-bottom:16px}
footer.site ul{list-style:none;font-size:13px}
footer.site li{margin-bottom:9px}
footer.site a:hover{color:#fff}
.footer-brand .logo-mark{border-color:#a8895a;color:#d8c8aa;margin-bottom:14px}
.footer-brand p{font-size:13px;max-width:300px}
.copyright{max-width:1280px;margin:40px auto 0;padding-top:22px;border-top:1px solid #46423c;font-size:12px;color:#8d8779;text-align:center}
