:root{
  --bg:#f7f3ec;
  --paper:#fffdf8;
  --ink:#24211d;
  --muted:#746b61;
  --line:#ded2c4;
  --accent:#7d171d;
  --accent-dark:#581014;
  --gold:#b6936a;
  --soft:#eee6dc;
  --shadow:0 18px 40px rgba(61,45,32,.10);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Manrope,Inter,Arial,sans-serif;line-height:1.55;overflow-x:hidden}
body:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.9),transparent 32%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.75),transparent 34%);z-index:-1}
img{max-width:100%;display:block}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.container{width:min(1180px,calc(100% - 40px));margin:auto;position:relative}
.serif{font-family:"Cormorant Garamond",Georgia,serif;font-weight:500;letter-spacing:0}
header{position:sticky;top:0;z-index:20;background:rgba(247,243,236,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(222,210,196,.75)}
.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:16px;color:inherit;text-decoration:none}
.monogram{font-family:Georgia,serif;font-size:34px;line-height:1;border:1px solid var(--ink);width:48px;height:48px;display:grid;place-items:center}
.brand strong{display:block;font-family:"Cormorant Garamond",Georgia,serif;font-size:23px;font-weight:600;line-height:1}
.brand span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
nav{display:flex;gap:34px;font-size:14px}
nav a{color:var(--ink);text-decoration:none}
nav a:hover, nav a[aria-current="page"]{color:var(--accent)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(125,23,29,.35);outline-offset:3px}
.btn{position:relative;isolation:isolate;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 26px;border:1px solid var(--accent);background:var(--accent);color:#fff;text-decoration:none;font-weight:600;font-size:14px;transition:transform .25s,box-shadow .25s,background .25s,border-color .25s;cursor:pointer}
.btn:not(.ghost){box-shadow:0 12px 28px rgba(125,23,29,.16)}
.btn:not(.ghost):before{content:"";position:absolute;inset:-40% -55%;z-index:-1;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.34) 49%,transparent 63%);transform:translateX(-70%) rotate(10deg);animation:btn-shimmer 5.8s ease-in-out infinite}
.btn:not(.ghost):after{content:"→";font-size:18px;line-height:1;transition:transform .25s}
.btn:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 16px 34px rgba(88,16,20,.18)}
.btn:not(.ghost):hover:after{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--accent)}
.btn.ghost:hover{background:#fff;color:var(--accent);box-shadow:0 12px 28px rgba(61,45,32,.08)}
.mobile-toggle{display:none;background:transparent;border:0;font-size:28px;color:var(--ink)}

.hero{min-height:760px;display:grid;align-items:center;border-bottom:1px solid var(--line);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;align-items:end;gap:50px}
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:28px}
.hero h1{font-size:86px;line-height:.92;margin:0 0 18px}
.hero h2{font-family:Georgia,serif;font-weight:400;font-size:28px;line-height:1.25;margin:0 0 6px}
.hero .accent-line{color:var(--accent);font-family:Georgia,serif;font-size:23px;margin-bottom:24px}
.lead{font-size:17px;color:#443d36;max-width:560px}
.actions{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap}
.hero-photo{position:relative;min-height:690px;display:flex;align-items:flex-end;justify-content:center;animation:portrait-enter 1s ease-out both}
.hero-photo:before{content:"";position:absolute;right:5%;bottom:0;width:80%;height:78%;background:linear-gradient(145deg,#ede2d6,#fff8f0);border-radius:260px 260px 0 0;box-shadow:var(--shadow);animation:portrait-bg-breathe 9s ease-in-out infinite}
.hero-photo img{position:relative;max-height:690px;max-width:100%;object-fit:contain;filter:drop-shadow(0 22px 30px rgba(55,43,34,.10));animation:portrait-breathe 8s ease-in-out infinite;transform-origin:50% 90%}
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
.trust div{border-top:1px solid var(--line);padding-top:16px;font-size:13px;color:var(--muted)}
.trust strong{display:block;color:var(--ink);font-size:14px}

section{padding:94px 0;border-bottom:1px solid var(--line)}
.section-head{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:end;margin-bottom:44px}
.kicker{font-size:12px;text-transform:uppercase;letter-spacing:.22em;color:var(--gold);font-weight:700}
.title{font-size:56px;line-height:1.02;margin:8px 0 0}
.section-head p{color:var(--muted);font-size:17px;max-width:610px}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.about-text{font-family:Georgia,serif;font-size:26px;line-height:1.38}
.about-text p{margin:0 0 22px}
.about-cards{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--line);background:rgba(255,253,248,.65)}
.about-card{padding:34px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-card:nth-child(2n){border-right:0}
.about-card:nth-last-child(-n+2){border-bottom:0}
.icon{font-size:30px;color:var(--gold);margin-bottom:18px}
.about-card h3{font-family:Georgia,serif;font-size:22px;font-weight:500;margin:0 0 10px}
.about-card p{margin:0;color:var(--muted);font-size:14px}
.directions .section-head{grid-template-columns:1fr 1fr}
.direction-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.direction-card{display:block;background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--ink);box-shadow:0 10px 24px rgba(61,45,32,.04);transition:.28s}
.direction-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:#b99b7a}
.card-image{height:270px;overflow:hidden;background:#ddd}
.card-image img{width:100%;height:100%;object-fit:cover;transition:.45s;filter:saturate(.88) contrast(.98)}
.direction-card:hover .card-image img{transform:scale(1.045)}
.card-body{padding:28px 30px 24px}
.card-body h3{font-size:34px;line-height:1.02;margin:0 0 18px}
.card-body p{min-height:92px;margin:0;color:#4f463d}
.price{display:block;margin:22px 0;color:var(--accent);font-weight:700}
.card-cta{border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between;align-items:center;font-weight:700;color:#3a332e}
.arrow{font-size:28px;transition:.25s}
.direction-card:hover .arrow{transform:translateX(8px);color:var(--accent)}

.value{background:#29231d;color:#f7f0e7}
.value .kicker,.value .title{color:#f7f0e7}
.value p{color:#cfc3b5}
.value-grid{display:grid;grid-template-columns:.72fr repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18)}
.value-intro,.value-item{padding:36px 28px}
.value-item{border-left:1px solid rgba(255,255,255,.18)}
.value-item span{font-family:Georgia,serif;color:var(--gold);font-size:32px}
.value-item h3{font-size:18px;margin:14px 0 10px}
.value-item p{font-size:14px;margin:0}

.portfolio-strip{display:grid;grid-template-columns:1.1fr repeat(4,1fr);gap:0;background:#211c17;color:#fff;overflow:hidden;border-radius:18px}
.portfolio-copy{padding:42px}
.portfolio-copy h2{font-size:46px;line-height:1;margin:0 0 24px}
.portfolio-strip a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4)}
.portfolio-strip img{width:100%;height:260px;object-fit:cover;filter:brightness(.75) saturate(.82);transition:transform .7s ease,filter .7s ease}
.portfolio-strip img:hover{transform:scale(1.045);filter:brightness(.9) saturate(.95)}
.process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line);background:rgba(255,253,248,.75)}
.process-step{padding:30px;border-right:1px solid var(--line)}
.process-step:last-child{border-right:0}
.process-step span{width:42px;height:42px;border:1px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold);font-family:Georgia,serif;margin-bottom:22px}
.process-step h3{font-size:17px;margin:0 0 10px}
.process-step p{font-size:14px;margin:0;color:var(--muted)}

.contact{padding-bottom:0}
.contact-panel{display:grid;grid-template-columns:.85fr 1.15fr;background:var(--paper);border:1px solid var(--line);border-radius:22px;overflow:hidden}
.contact-copy{padding:54px}
.contact-copy h2{font-size:54px;line-height:1.02;margin:0 0 18px}
.contact-form{padding:54px;background:linear-gradient(145deg,#fffdf8,#efe4da)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;padding:15px 16px;font:inherit;margin-bottom:14px}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
textarea{min-height:120px;resize:vertical}
.fine{font-size:12px;color:var(--muted);margin-top:10px}
.contacts-list{display:grid;gap:10px;margin-top:30px;color:#4a423b}
.contacts-list a{color:inherit;text-decoration:none}

.inner-hero{padding:95px 0 70px}
.inner-hero h1{font-size:72px;line-height:.98;margin:0 0 22px}
.inner-hero p{font-size:19px;max-width:760px;color:var(--muted)}
.page-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:start}
.service-list{display:grid;gap:14px;margin:0;padding:0;list-style:none}
.service-list li{background:var(--paper);border:1px solid var(--line);padding:18px 22px;border-radius:14px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery-grid img{height:250px;width:100%;object-fit:cover;border-radius:14px;border:1px solid var(--line);transition:transform .55s ease,filter .55s ease,box-shadow .55s ease}
.gallery-grid img:hover{transform:translateY(-4px) scale(1.015);filter:saturate(1.04) contrast(1.02);box-shadow:var(--shadow)}
.note{background:rgba(255,253,248,.7);border:1px solid var(--line);border-radius:18px;padding:28px;color:var(--muted)}

footer{background:#211c17;color:#e8ded3;padding:34px 0}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:20px;font-size:13px}
.footer-grid a{color:#e8ded3;text-decoration:none;margin-left:20px}

.reveal-on-scroll{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
.reveal-on-scroll.is-visible{opacity:1;transform:none}
.reveal-on-scroll:nth-child(2){transition-delay:.06s}
.reveal-on-scroll:nth-child(3){transition-delay:.12s}
.reveal-on-scroll:nth-child(4){transition-delay:.18s}

@keyframes btn-shimmer{
  0%,58%{transform:translateX(-70%) rotate(10deg);opacity:0}
  66%{opacity:1}
  82%,100%{transform:translateX(70%) rotate(10deg);opacity:0}
}
@keyframes portrait-enter{
  from{opacity:0;transform:translateY(24px) scale(.985)}
  to{opacity:1;transform:none}
}
@keyframes portrait-breathe{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(0,-6px,0) scale(1.012)}
}
@keyframes portrait-bg-breathe{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.025);opacity:.9}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal-on-scroll{opacity:1;transform:none}
}

@media(max-width:900px){
  .container{width:min(100% - 28px,720px)}
  nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--paper);padding:20px;border-bottom:1px solid var(--line)}
  nav.open{display:grid;gap:16px}
  .mobile-toggle{display:block}
  .nav{height:68px}
  .brand .monogram{width:42px;height:42px;font-size:28px}
  .btn.nav-btn{display:none}
  .hero{min-height:auto;padding:60px 0 0}
  .hero-grid,.section-head,.about-grid,.contact-panel,.page-grid{grid-template-columns:1fr}
  .hero h1{font-size:58px}
  .hero h2{font-size:24px}
  .hero-photo{min-height:430px}
  .hero-photo img{max-height:430px}
  .trust,.direction-grid,.process-grid,.gallery-grid{grid-template-columns:1fr}
  .about-cards{grid-template-columns:1fr}
  .about-card,.about-card:nth-child(2n),.about-card:nth-last-child(-n+2){border-right:0;border-bottom:1px solid var(--line)}
  .value-grid{grid-template-columns:1fr}
  .value-item{border-left:0;border-top:1px solid rgba(255,255,255,.18)}
  .portfolio-strip{grid-template-columns:1fr 1fr}
  .portfolio-copy{grid-column:1/-1}
  .form-row{grid-template-columns:1fr}
  .footer-grid{display:grid}
  .footer-grid a{margin:0 20px 0 0}
  .title{font-size:42px}
  section{padding:70px 0}
}
@media(max-width:520px){
  .hero h1{font-size:46px}
  .inner-hero h1{font-size:44px}
  .title,.contact-copy h2{font-size:36px}
  .actions{display:grid}
  .btn{width:100%}
  .portfolio-strip{grid-template-columns:1fr}
  .card-image{height:230px}
  .hero .accent-line{font-size:20px}
}


.portfolio-showcase{background:#f2ebe1}
.portfolio-mosaic{display:grid;grid-template-columns:1.15fr 1fr 1fr 1fr;grid-auto-rows:300px;gap:18px}
.portfolio-tile{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--line);background:#211c17;color:#fff;box-shadow:0 12px 28px rgba(61,45,32,.06)}
.portfolio-tile img{width:100%;height:100%;object-fit:cover;filter:brightness(.82) saturate(.96);transition:transform .65s ease,filter .65s ease}
.portfolio-tile:hover img{transform:scale(1.045);filter:brightness(.95) saturate(1.02)}
.portfolio-tile div{position:absolute;left:0;right:0;bottom:0;padding:22px;background:linear-gradient(transparent,rgba(20,16,13,.86))}
.portfolio-tile span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:#d8bd96;font-weight:700;margin-bottom:6px}
.portfolio-tile h3{font-family:Georgia,serif;font-weight:500;font-size:28px;line-height:1.02;margin:0 0 8px}
.portfolio-tile p{font-size:14px;line-height:1.42;margin:0;color:#f4ece2}
.tile-large{grid-row:span 2}
.tile-wide{grid-column:span 2}
.portfolio-note-line{margin-top:22px;padding:20px 24px;border:1px solid var(--line);background:var(--paper);border-radius:16px;color:#4a423b}

.story-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.story-gallery article{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 10px 24px rgba(61,45,32,.04)}
.story-gallery img{width:100%;height:260px;object-fit:cover;transition:transform .55s ease,filter .55s ease}
.story-gallery article:hover img{transform:scale(1.035);filter:saturate(1.04) contrast(1.02)}
.story-gallery h3{font-family:Georgia,serif;font-weight:500;font-size:24px;line-height:1.05;margin:20px 20px 8px}
.story-gallery p{margin:0 20px 22px;color:var(--muted);font-size:14px}

@media(max-width:900px){
  .portfolio-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:260px}
  .story-gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .portfolio-mosaic,.story-gallery{grid-template-columns:1fr}
  .tile-large,.tile-wide{grid-row:auto;grid-column:auto}
}
