*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Manrope",sans-serif;background:#fff;color:#1a1a1a;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:#1a1a1a;color:#fff}
img{display:block;max-width:100%}
.logo{height:16px;width:auto;color:#fff}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal-right.visible{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.95);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal-scale.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:14px clamp(20px,4vw,40px);display:flex;justify-content:space-between;align-items:center;background:#2A3425;transition:background .5s,backdrop-filter .5s}
.nav.scrolled{background:rgba(42,52,37,.82);backdrop-filter:blur(12px)}
.nav a{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;text-decoration:none;opacity:.6;transition:opacity .3s}
.nav a:hover{opacity:1}
.nav-r{display:flex;gap:clamp(10px,2vw,20px);align-items:center}
.nav-btn{opacity:1!important;background:#fff;color:#1a1a1a!important;padding:6px 14px;letter-spacing:.08em}

/* HERO */
.hero{position:relative;min-height:90vh;overflow:hidden;background:#111}
.hero>img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.55}
.hero-c{position:relative;z-index:2;padding:0 clamp(20px,4vw,40px);min-height:90vh;display:flex;flex-direction:column;justify-content:flex-end}
.hero h1{font-size:clamp(36px,7vw,72px);font-weight:300;color:#fff;line-height:1.12;letter-spacing:-.02em;max-width:600px;margin-bottom:clamp(32px,4vw,48px)}
.hero-info{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.15)}
.hero-info p{font-size:15px;color:rgba(255,255,255,.7);line-height:1.7}
.hero-info>div:first-child{padding:clamp(16px,2vw,24px) clamp(16px,2vw,24px) clamp(16px,2vw,24px) 0;border-right:1px solid rgba(255,255,255,.15)}
.hero-info>div:last-child{padding:clamp(16px,2vw,24px)}
.hero-link{display:inline-block;margin-top:12px;font-size:10px;color:#fff;text-decoration:none;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid #fff;padding-bottom:2px}

/* MISSION */
.mission{display:grid;grid-template-columns:2fr 3fr;min-height:500px}
.mission-text{background:#2A3425;color:#fff;padding:clamp(32px,5vw,56px) clamp(20px,4vw,40px);display:flex;flex-direction:column;justify-content:space-between}
.mission-text h2{font-size:clamp(22px,3vw,32px);font-weight:300;line-height:1.35;margin-bottom:16px}
.mission-photo{position:relative;overflow:hidden}
.mission-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.nums{display:flex;gap:clamp(20px,3vw,36px);margin-top:20px}
.nums div>div:first-child{font-size:clamp(22px,3vw,32px);font-weight:200}
.nums div>div:last-child{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:2px}
.label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.label-dark{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:24px}
.btn-o{display:inline-block;margin-top:20px;font-size:10px;color:#fff;text-decoration:none;letter-spacing:.08em;text-transform:uppercase;border:1px solid rgba(255,255,255,.25);padding:8px 16px}
.btn-d{display:inline-block;margin-top:20px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#1a1a1a;text-decoration:none;border:1px solid #1a1a1a;padding:10px 20px}

/* PHOTO GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.g21{display:grid;grid-template-columns:2fr 1fr;gap:2px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,28px)}

/* PROCESS */
.process{background:#f0ede5;border-top:1px solid #e0ddd5;border-bottom:1px solid #e0ddd5}
.process-label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:12px clamp(20px,4vw,40px);border-bottom:1px solid #e0ddd5}
.process-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr}
.process-cell{padding:clamp(24px,3vw,40px) clamp(16px,2vw,24px);border-right:1px solid #e0ddd5;display:flex;flex-direction:column;justify-content:space-between;min-height:clamp(240px,30vw,360px)}
.process-cell:last-child{border-right:none}
.process-n{font-size:clamp(56px,8vw,80px);font-weight:200;color:#d5d0c8;line-height:1}
.process-t{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.process-d{font-size:12px;color:#888;line-height:1.6}

/* SECTION */
.sec{padding:clamp(56px,8vw,80px) clamp(20px,4vw,40px)}

/* PROJECTS */
.proj-strip{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.proj-strip::-webkit-scrollbar{display:none}
.proj-strip img{height:clamp(120px,18vw,200px);width:auto;object-fit:cover;flex-shrink:0;cursor:pointer;transition:opacity .3s}
.proj-strip img:hover{opacity:.8}

/* PRICES */
.prices-bg{background:#f0ede5}
.price-card{background:#fff;padding:clamp(20px,3vw,32px)}
.price-card h3{font-size:12px;font-weight:600;line-height:1.3;min-height:2.6em;-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word}
.price-v{font-size:clamp(26px,3.5vw,36px);font-weight:200;margin:8px 0;letter-spacing:-.02em}
.price-card li{font-size:11px;color:#888;padding:4px 0;border-top:1px solid #f0ede5;list-style:none}

/* QUOTE */
.quote{background:#f0ede5;padding:clamp(48px,7vw,80px) clamp(20px,4vw,40px);text-align:center}
.quote p{font-size:clamp(20px,3vw,30px);font-weight:300;line-height:1.45;max-width:640px;margin:0 auto;color:#444}
.quote2{padding:clamp(40px,6vw,64px) clamp(20px,4vw,40px);text-align:center;border-top:1px solid #eee}
.quote2 p{font-size:clamp(16px,2.2vw,22px);font-weight:400;line-height:1.6;max-width:520px;margin:0 auto;color:#888}

/* FAQ */
.faq-item{border-top:1px solid #eee;padding:14px 0;cursor:pointer}
.faq-q{display:flex;justify-content:space-between;align-items:center;font-size:14px}
.faq-q span{font-size:16px;color:#ccc;transition:transform .3s;flex-shrink:0;margin-left:16px}
.faq-a{font-size:13px;color:#888;line-height:1.7;max-height:0;overflow:hidden;transition:max-height .4s,padding .4s;padding-top:0}
.faq-a.open{max-height:200px;padding-top:10px}

/* CALCULATOR */
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:start;margin-top:24px}
.calc-h{font-size:clamp(22px,3vw,32px);font-weight:300;line-height:1.3;letter-spacing:-.01em}
.calc-sub{font-size:13px;color:#888;line-height:1.7;margin-top:12px;max-width:420px}
.calc-form{margin-top:28px}
.calc-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-top:1px solid #eee;gap:16px}
.calc-row:last-child{border-bottom:1px solid #eee}
.calc-row label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#1a1a1a;display:flex;align-items:center}
.calc-svg{width:100%;max-width:380px;height:auto;display:block;margin:28px auto 12px}
.dim line{stroke:#999;stroke-width:.8;transition:stroke .2s,stroke-width .2s}
.dim circle{fill:#1a1a1a;transition:fill .2s}
.dim text{fill:#fff;font-size:11px;font-weight:600;text-anchor:middle;dominant-baseline:central;pointer-events:none;font-family:Manrope,sans-serif}
.dim{cursor:pointer}
.dim.active circle{fill:#2A3425}
.dim.active line{stroke:#2A3425;stroke-width:1.2}
.calc-badge{display:inline-flex;flex-shrink:0;width:20px;height:20px;border-radius:50%;background:#1a1a1a;color:#fff;font-size:10px;font-weight:600;align-items:center;justify-content:center;margin-right:10px;transition:background .2s}
.calc-row.active .calc-badge{background:#2A3425}
.calc-row input,.calc-row select{font-family:inherit;font-size:14px;color:#1a1a1a;background:transparent;border:none;padding:4px 0;text-align:right;width:170px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}
.calc-row input::-webkit-outer-spin-button,.calc-row input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.calc-row input[type=number]{-moz-appearance:textfield}
.calc-row select{cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23999' fill='none' stroke-width='1.5'/></svg>");background-repeat:no-repeat;background-position:right center;padding-right:18px}
.calc-result{background:#f0ede5;padding:clamp(28px,4vw,40px);align-self:end}
.calc-line{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-top:1px solid #e0ddd5;font-size:13px;color:#666}
.calc-line:first-child{border-top:none;padding-top:0}
.calc-line>span:last-child{color:#1a1a1a;font-weight:500}
.calc-total{margin-top:8px;padding-top:20px;border-top:1px solid #1a1a1a}
.calc-total>span:first-child{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#1a1a1a}
.calc-total>span:last-child{font-size:clamp(26px,3vw,32px);font-weight:200;letter-spacing:-.02em}
.calc-note{font-size:11px;color:#999;margin-top:14px;line-height:1.7}

/* CONTACT */
.contact{background:#2A3425;color:#fff;padding:clamp(56px,8vw,80px) clamp(20px,4vw,40px)}
.contact a{font-size:clamp(24px,4vw,36px);font-weight:200;color:#fff;text-decoration:none;display:block;line-height:1.4}

/* MOOD PHOTO */
.mood{position:relative;height:clamp(200px,30vw,360px);overflow:hidden}
.mood img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}

/* OVERLAY */
.ov{position:fixed;inset:0;z-index:300;background:#2A3425;display:flex;align-items:center;justify-content:center;padding:32px;color:#f8f7f4;animation:fadeIn .3s}
.ov .logo{color:#f8f7f4}
.ov-close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:10px;color:rgba(248,247,244,.3);cursor:pointer;letter-spacing:.1em;text-transform:uppercase;font-family:inherit}
.ov input,.ov textarea{width:100%;border:none;border-bottom:1px solid rgba(248,247,244,.08);padding:6px 0;font-family:inherit;font-size:12px;color:#f8f7f4;background:transparent;outline:none}
.ov textarea{min-height:40px;resize:vertical}
.ov-btn{margin-top:6px;background:#f8f7f4;color:#2A3425;border:none;padding:10px 22px;font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}

.side{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(24px,4vw,48px);align-items:start}
.footer{padding:14px clamp(20px,4vw,40px);display:flex;justify-content:space-between;font-size:10px;color:#ccc;border-top:1px solid #eee}
.footer a{color:#ccc;text-decoration:none}

@media(max-width:768px){
  .mission,.side,.calc-grid{grid-template-columns:1fr!important}
  .hero-info,.g2,.g21,.g3,.process-grid{grid-template-columns:1fr!important}
  .process-cell{min-height:auto!important;border-right:none!important;border-bottom:1px solid #e0ddd5}
  .nav-r a:nth-child(-n+3){display:none}
}