
:root{
  --navy:#0B1728;
  --heritage:#1F4F73;
  --blue:#2F6F9F;
  --soft:#F5F7FA;
  --white:#fff;
  --line:#D7E1EA;
  --ink:#0B1728;
  --muted:#50657A;
  --shadow:0 24px 70px rgba(11,23,40,.13);
  --radius:28px;
  --rail:305px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--soft);color:var(--ink);font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Arial, sans-serif;line-height:1.55}.skip{position:absolute;left:-999px;top:auto}.skip:focus{left:20px;top:20px;background:#fff;z-index:99;padding:12px 16px}.site-rail{position:fixed;left:0;top:0;bottom:0;width:var(--rail);background:var(--navy);color:#fff;padding:30px;display:flex;flex-direction:column;gap:30px;z-index:20}.rail-logo{color:#fff;text-decoration:none;display:grid;grid-template-columns:58px 1fr;gap:16px;align-items:center}.mark{display:inline-grid;place-items:center;width:54px;height:54px;border:2px solid var(--blue);box-shadow:inset 0 0 0 4px rgba(255,255,255,.08);border-radius:10px;font:700 20px/1 Georgia,serif;letter-spacing:.04em;color:#fff;background:var(--navy)}.rail-logo strong{display:block;font-family:Georgia,serif;font-size:23px;line-height:1.08}.rail-logo em{display:block;font-style:normal;text-transform:uppercase;letter-spacing:.18em;color:#B7D2E8;font-weight:800;font-size:10px;margin-top:8px}.rail-nav{display:flex;flex-direction:column;gap:4px;border-top:1px solid rgba(255,255,255,.13);border-bottom:1px solid rgba(255,255,255,.13);padding:18px 0}.nav-link{color:#DDEBFF;text-decoration:none;padding:11px 13px;border-radius:12px;font-weight:750}.nav-link:hover,.nav-link.active{background:#fff;color:var(--navy)}.rail-card{background:linear-gradient(180deg,#1F4F73,#163955);padding:20px;border-radius:22px;box-shadow:0 18px 40px rgba(0,0,0,.25)}.rail-small{text-transform:uppercase;letter-spacing:.16em;color:#B7D2E8;font-size:11px;font-weight:800;margin:0 0 6px}.rail-phone{display:block;color:#fff;text-decoration:none;font-size:25px;font-weight:850;margin:4px 0 14px}.rail-button{display:inline-flex;background:#fff;color:var(--navy);text-decoration:none;font-weight:850;padding:12px 15px;border-radius:999px}.rail-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;font-size:14px}.rail-foot a{color:#B7D2E8}.mobile-head{display:none}.page-wrap{margin-left:var(--rail);min-height:100vh}.hero-dossier{padding:34px clamp(22px,5vw,78px) 60px;background:linear-gradient(135deg,#fff 0%,#fff 48%,#E9F3FA 100%);position:relative;overflow:hidden}.hero-dossier:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(47,111,159,.06) 1px, transparent 1px),linear-gradient(90deg,rgba(47,111,159,.06) 1px, transparent 1px);background-size:44px 44px;mask-image:linear-gradient(90deg,transparent,#000 30%,#000 70%,transparent);pointer-events:none}.hero-topline{position:relative;z-index:2;display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:32px;text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:850;color:var(--heritage)}.hero-topline a{color:var(--navy);text-decoration:none}.hero-paper{position:relative;z-index:3;background:rgba(255,255,255,.86);backdrop-filter:blur(8px);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:34px;padding:clamp(28px,5vw,58px);display:grid;grid-template-columns:1.4fr .82fr;gap:36px}.eyebrow{text-transform:uppercase;letter-spacing:.2em;color:var(--heritage);font-weight:900;font-size:12px;margin:0 0 13px}.hero-copy h1,.page-hero h1{font-size:clamp(46px,7vw,96px);line-height:.94;letter-spacing:-.075em;margin:0 0 24px;max-width:930px}.lead{font-size:clamp(18px,2vw,22px);max-width:760px;color:#19304A;margin:0}.hero-actions,.form-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:999px;padding:15px 22px;font-weight:850;border:1px solid var(--heritage);cursor:pointer}.btn.primary{background:var(--heritage);color:#fff;box-shadow:0 14px 30px rgba(31,79,115,.22)}.btn.secondary{background:#fff;color:var(--navy)}.hero-notes{display:grid;gap:14px;align-content:end}.hero-notes div{background:var(--navy);color:#fff;border-radius:22px;padding:22px}.hero-notes b{display:block;font-size:36px;line-height:1}.hero-notes span{display:block;color:#DDEBFF;margin-top:5px}.project-board{position:relative;z-index:2;margin-top:34px;display:grid;grid-template-columns:1.2fr .8fr 1fr .8fr;grid-auto-rows:190px;gap:18px;align-items:stretch}.board-card{margin:0;background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);position:relative}.board-card img{width:100%;height:100%;object-fit:cover;display:block}.board-large{grid-row:span 2}.board-tall{grid-row:span 2}.board-card figcaption{position:absolute;left:14px;right:14px;bottom:14px;background:rgba(255,255,255,.93);border-radius:16px;padding:12px}.board-card span,.work-strip small{display:block;text-transform:uppercase;letter-spacing:.14em;color:var(--heritage);font-size:10px;font-weight:900}.board-card b{font-size:18px}.section-pad{padding:clamp(50px,7vw,95px) clamp(22px,5vw,78px)}.no-top{padding-top:20px}.personal-panel{display:grid;grid-template-columns:110px .9fr 1fr;gap:42px;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.panel-number{font-family:Georgia,serif;color:#E0EAF3;font-size:88px;line-height:1}.panel-copy h2,.section-head h2,.area-copy h2,.contact-split h2,.seo-note h2{font-size:clamp(34px,4.6vw,62px);letter-spacing:-.055em;line-height:1;margin:0 0 16px}.panel-text{font-size:19px;color:#213D58}.service-ledger{background:#fff}.section-head{max-width:850px;margin-bottom:32px}.section-head p:not(.eyebrow){font-size:18px;color:var(--muted)}.two-col-head{max-width:100%;display:flex;justify-content:space-between;gap:24px;align-items:end}.text-link{color:var(--heritage);font-weight:850;text-decoration:none}.ledger-list{display:grid;border-top:1px solid var(--line)}.ledger-row{display:grid;grid-template-columns:74px minmax(220px,.7fr) 1fr 120px;gap:24px;align-items:center;padding:26px 0;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink)}.ledger-row span{font-family:Georgia,serif;color:var(--blue);font-size:28px}.ledger-row b{font-size:24px}.ledger-row p{margin:0;color:var(--muted)}.ledger-row em{font-style:normal;font-weight:850;color:var(--heritage)}.ledger-row:hover b{text-decoration:underline}.muted{background:linear-gradient(180deg,#F5F7FA,#fff)}.work-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}.work-strip article{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 18px 50px rgba(11,23,40,.08)}.work-strip img{height:210px;width:100%;object-fit:cover;display:block}.work-strip div{padding:16px}.work-strip h3{margin:5px 0 0;font-size:18px;line-height:1.2}.area-dossier{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center;background:#fff}.area-copy p:not(.eyebrow){font-size:19px;color:var(--muted)}.radius-map{height:500px;border-radius:50%;border:2px dashed var(--blue);background:radial-gradient(circle at center,#fff 0 23%,#EDF5FA 24% 54%,#fff 55%);position:relative;box-shadow:inset 0 0 0 22px rgba(47,111,159,.05)}.radius-map.large{height:min(58vw,620px)}.centre{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--navy);color:#fff;border-radius:50%;width:118px;height:118px;display:grid;place-items:center;font-family:Georgia,serif;font-size:22px}.place{position:absolute;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-weight:800;box-shadow:0 12px 30px rgba(11,23,40,.08)}.p1{left:18%;top:24%}.p2{left:22%;bottom:22%}.p3{right:16%;top:22%}.p4{right:11%;bottom:25%}.p5{left:43%;top:10%}.p6{right:35%;bottom:10%}.p7{left:8%;top:50%}.p8{right:6%;top:50%}.dark{background:var(--navy);color:#fff}.dark .eyebrow{color:#B7D2E8}.dark .section-head h2{color:#fff}.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.quote-grid blockquote{margin:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:24px}.quote-grid p{font-size:19px;margin:0 0 22px}.quote-grid cite{color:#B7D2E8;font-style:normal;font-weight:800}.contact-split{display:grid;grid-template-columns:1fr .9fr;gap:34px;align-items:start;background:#fff}.contact-split p:not(.eyebrow){font-size:19px;color:var(--muted)}.contact-card{display:grid;gap:12px;background:var(--soft);border:1px solid var(--line);border-radius:28px;padding:24px}.contact-card a,.contact-methods a,.contact-methods div{display:block;text-decoration:none;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px}.contact-card span,.contact-methods span{display:block;text-transform:uppercase;letter-spacing:.15em;color:var(--heritage);font-size:11px;font-weight:900}.contact-card b,.contact-methods b{display:block;margin-top:4px}.site-footer{background:#07111F;color:#fff;padding:38px clamp(22px,5vw,78px);display:grid;gap:28px}.footer-brand{display:flex;gap:14px;align-items:center}.footer-brand b{display:block;font-family:Georgia,serif;font-size:24px}.footer-brand small{display:block;color:#B7D2E8;text-transform:uppercase;letter-spacing:.16em;font-weight:800}.footer-cols{display:flex;gap:80px}.footer-cols h4{margin:0 0 10px}.footer-cols a{display:block;color:#DDEBFF;text-decoration:none;margin:5px 0}.site-footer p{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;color:#B7D2E8;margin:0}.page-hero{padding:clamp(58px,8vw,110px) clamp(22px,5vw,78px);background:linear-gradient(135deg,#fff,#E9F3FA);border-bottom:1px solid var(--line)}.page-hero.compact h1{font-size:clamp(44px,6vw,82px);max-width:980px}.page-hero p:not(.eyebrow){font-size:21px;max-width:790px;color:var(--muted)}.gallery-tools{padding:26px clamp(22px,5vw,78px);background:#fff;display:flex;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:4}.filter-btn{border:1px solid var(--line);background:#fff;color:var(--navy);border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}.filter-btn.active{background:var(--heritage);color:#fff}.masonry-gallery{columns:3 280px;column-gap:18px;background:#fff}.masonry-gallery figure{break-inside:avoid;margin:0 0 18px;background:var(--soft);border:1px solid var(--line);border-radius:22px;overflow:hidden}.masonry-gallery img{width:100%;height:auto;display:block}.masonry-gallery figcaption{padding:14px;font-weight:800}.masonry-gallery figcaption span{display:block;color:var(--heritage);text-transform:uppercase;letter-spacing:.14em;font-size:10px}.area-page-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;background:#fff}.area-list-page{display:grid;grid-template-columns:1fr 1fr;gap:12px}.area-list-page a{display:block;background:var(--soft);border:1px solid var(--line);border-radius:18px;padding:18px;text-decoration:none;color:var(--navy)}.area-list-page span{display:block;text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--heritage);font-weight:900}.area-list-page b{font-size:22px}.contact-page{display:grid;grid-template-columns:.8fr 1fr;gap:34px;background:#fff}.contact-methods{display:grid;gap:14px}.contact-methods em{font-style:normal;color:var(--muted);display:block;margin-top:4px}.quote-form{background:var(--soft);border:1px solid var(--line);border-radius:28px;padding:26px;display:grid;gap:16px}.quote-form label{display:grid;gap:7px;font-weight:850}.quote-form input,.quote-form textarea{width:100%;border:1px solid #C8D6E2;border-radius:14px;padding:14px 15px;font:inherit;background:#fff}.quote-form textarea{resize:vertical}.quote-form button{width:max-content}.form-hint{color:var(--muted);margin:0}.service-detail{display:grid;grid-template-columns:1fr .8fr;gap:36px;background:#fff}.service-detail h2{font-size:44px;letter-spacing:-.04em;line-height:1.1}.service-detail p,.service-detail li{font-size:18px;color:var(--muted)}.service-detail img{width:100%;height:460px;object-fit:cover;border-radius:28px;border:1px solid var(--line);box-shadow:var(--shadow)}.swatch-page{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;background:#fff}.swatch{border:1px solid var(--line);border-radius:20px;padding:16px}.swatch span{display:block;height:90px;border-radius:14px;margin-bottom:12px}.swatch b{display:block}.swatch code{color:var(--muted)}@media (max-width:1180px){:root{--rail:0px}.site-rail{display:none}.mobile-head{display:flex;position:sticky;top:0;z-index:20;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--navy);color:#fff}.mobile-brand{display:flex;gap:10px;align-items:center;color:#fff;text-decoration:none;font-weight:850}.mobile-brand .mark{width:42px;height:42px;font-size:15px}.mobile-cta{background:#fff;color:var(--navy);padding:10px 14px;border-radius:999px;text-decoration:none;font-weight:850}.page-wrap{margin-left:0}.hero-paper,.personal-panel,.area-dossier,.contact-split,.area-page-grid,.contact-page,.service-detail{grid-template-columns:1fr}.project-board{grid-template-columns:1fr 1fr}.work-strip{grid-template-columns:repeat(2,1fr)}.quote-grid{grid-template-columns:1fr}.ledger-row{grid-template-columns:54px 1fr}.ledger-row p,.ledger-row em{grid-column:2}.hero-topline{display:none}}@media (max-width:720px){.hero-dossier,.section-pad,.page-hero{padding-left:18px;padding-right:18px}.hero-copy h1,.page-hero.compact h1{font-size:44px;letter-spacing:-.06em}.hero-paper{padding:22px;border-radius:24px}.project-board{grid-template-columns:1fr;grid-auto-rows:220px}.board-large,.board-tall{grid-row:auto}.personal-panel{gap:10px}.panel-number{font-size:52px}.ledger-row{grid-template-columns:1fr;gap:8px}.ledger-row p,.ledger-row em{grid-column:auto}.work-strip{grid-template-columns:1fr}.radius-map{height:380px}.place{font-size:12px;padding:6px 9px}.area-list-page,.footer-cols{grid-template-columns:1fr;display:grid;gap:14px}.contact-page{gap:20px}.swatch-page{grid-template-columns:1fr}.quote-form button{width:100%}}
