*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --orange:#F5A623;--orange-dark:#C47A0A;
  --black:#111008;--off-white:#FAF7F0;--cream:#F0EAD8;
  --gray:#7A7265;--light-gray:#E8E2D6;--white:#FFFFFF;
  --wood-light:#C8923A;--wood-mid:#A0682A;--wood-dark:#6B3E15;
  --tx-red:#BF0A30;--tx-blue:#002868;
}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--off-white);color:var(--black);overflow-x:hidden;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:var(--black);border-bottom:2px solid var(--orange);}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;color:var(--orange);text-decoration:none;}
.nav-logo span{color:var(--white);}
.nav-links{display:flex;gap:28px;list-style:none;}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--white);text-decoration:none;opacity:0.7;transition:opacity 0.2s;}
.nav-links a:hover{opacity:1;color:var(--orange);}
.nav-cta{background:var(--orange);color:var(--black);border:none;padding:10px 24px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:background 0.2s,transform 0.1s;}
.nav-cta:hover{background:var(--orange-dark);transform:translateY(-1px);}

/* HERO */
.hero{min-height:100vh;background:var(--black);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding-top:64px;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(245,166,35,0.03) 60px,rgba(245,166,35,0.03) 61px);pointer-events:none;}
.hero-left{padding:80px 60px 80px 80px;position:relative;z-index:1;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-bottom:28px;}
.hero-eyebrow::before{content:'';display:block;width:32px;height:2px;background:var(--orange);}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(68px,7.5vw,108px);line-height:0.92;color:var(--white);letter-spacing:2px;margin-bottom:28px;}
.hero-title .accent{color:var(--orange);}
.hero-sub{font-size:18px;font-weight:300;line-height:1.7;color:rgba(255,255,255,0.6);max-width:440px;margin-bottom:48px;}
.hero-sub strong{color:var(--orange);font-weight:500;}
.hero-sub em{color:var(--wood-light);font-style:normal;font-weight:500;}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}
.btn-primary{background:var(--orange);color:var(--black);border:none;padding:18px 40px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:15px;cursor:pointer;border-radius:2px;transition:all 0.2s;text-decoration:none;display:inline-block;}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);}
.btn-ghost{color:var(--white);border:1px solid rgba(255,255,255,0.3);padding:17px 36px;background:transparent;font-family:'DM Sans',sans-serif;font-weight:400;font-size:15px;cursor:pointer;border-radius:2px;transition:all 0.2s;text-decoration:none;display:inline-block;}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange);}
.hero-stats{display:flex;gap:40px;margin-top:56px;padding-top:40px;border-top:1px solid rgba(255,255,255,0.1);}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--orange);line-height:1;}
.stat-label{font-size:12px;font-weight:400;color:rgba(255,255,255,0.4);letter-spacing:0.5px;margin-top:4px;}
.hero-right{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;padding:80px 60px;min-height:100vh;}
.box-wrapper{position:relative;width:100%;max-width:480px;}
.box-wrapper svg{width:100%;height:auto;}
.float-badge{position:absolute;background:var(--white);border-radius:8px;padding:12px 18px;box-shadow:0 8px 32px rgba(0,0,0,0.4);display:flex;align-items:center;gap:10px;}
.badge-top{top:20px;right:-20px;animation:floatY 3s ease-in-out infinite;}
.badge-bottom{bottom:40px;left:-30px;animation:floatY 3s ease-in-out infinite 1.5s;}
.badge-icon{width:32px;height:32px;border-radius:50%;background:var(--wood-mid);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:white;font-weight:700;font-size:13px;}
.badge-text{font-size:12px;font-weight:500;color:var(--black);}
.badge-sub{font-size:11px;color:var(--gray);margin-top:1px;}
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}

/* MARQUEE */
.marquee-strip{background:var(--orange);padding:14px 0;overflow:hidden;}
.marquee-inner{display:flex;gap:60px;width:max-content;animation:marqueeScroll 22s linear infinite;}
.marquee-item{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;color:var(--black);white-space:nowrap;display:flex;align-items:center;gap:20px;}
.marquee-dot{width:6px;height:6px;background:var(--black);border-radius:50%;}
@keyframes marqueeScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* WOOD BANNER */
.wood-banner{background:var(--wood-dark);padding:44px 80px;display:grid;grid-template-columns:1fr auto 1fr;gap:48px;align-items:center;border-top:3px solid var(--wood-light);border-bottom:3px solid var(--wood-light);}
.wood-banner-tag{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--wood-light);text-transform:uppercase;margin-bottom:8px;}
.wood-banner-title{font-family:'Bebas Neue',sans-serif;font-size:36px;color:var(--white);letter-spacing:1px;line-height:1;}
.wood-banner-sub{font-size:14px;color:rgba(255,255,255,0.5);margin-top:8px;line-height:1.6;}
.wood-divider{width:1px;background:rgba(255,255,255,0.12);align-self:stretch;}
.wood-badges{display:flex;flex-direction:column;gap:12px;}
.wood-badge{display:flex;align-items:center;gap:10px;}
.wood-badge-dot{width:8px;height:8px;background:var(--wood-light);border-radius:50%;flex-shrink:0;}
.wood-badge-text{font-size:13px;color:rgba(255,255,255,0.75);}

/* SECTIONS */
section{padding:100px 80px;}
.section-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.section-label::after{content:'';flex:1;max-width:48px;height:1px;background:var(--orange);}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(44px,5vw,72px);line-height:1;letter-spacing:1px;margin-bottom:20px;}

/* HOW */
.how-section{background:var(--black);color:var(--white);}
.how-section .section-title{color:var(--white);}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:64px;border:1px solid rgba(255,255,255,0.1);}
.how-step{padding:40px 28px;border-right:1px solid rgba(255,255,255,0.1);position:relative;transition:background 0.3s;}
.how-step:last-child{border-right:none;}
.how-step:hover{background:rgba(245,166,35,0.05);}
.step-num{font-family:'Bebas Neue',sans-serif;font-size:72px;color:rgba(245,166,35,0.12);line-height:1;margin-bottom:12px;}
.step-icon{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--orange);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.step-title{font-weight:700;font-size:16px;color:var(--white);margin-bottom:10px;}
.step-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.7;}
.step-wood-tag{display:inline-block;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--wood-light);background:rgba(200,146,58,0.12);border:1px solid rgba(200,146,58,0.25);padding:3px 8px;border-radius:20px;margin-bottom:10px;}

/* GALLERY */
.gallery-section{background:var(--black);padding:100px 80px;}
.gallery-section .section-title{color:var(--white);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px;}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer;}
.gallery-item:first-child{grid-column:span 2;aspect-ratio:unset;}
.gallery-item svg,.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s ease;}
.gallery-item:hover svg,.gallery-item:hover img{transform:scale(1.04);}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,transparent 50%);opacity:0;transition:opacity 0.3s;}
.gallery-item:hover .gallery-overlay{opacity:1;}
.gallery-tag{position:absolute;bottom:16px;left:16px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:white;text-transform:uppercase;opacity:0;transition:opacity 0.3s;}
.gallery-item:hover .gallery-tag{opacity:1;}
.gallery-pkg-badge{position:absolute;top:14px;right:14px;padding:4px 12px;border-radius:20px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1.5px;font-weight:500;}
.badge-basic{background:rgba(255,255,255,0.15);color:white;backdrop-filter:blur(4px);}
.badge-complete{background:rgba(245,166,35,0.85);color:var(--black);}
.badge-signature{background:rgba(191,10,48,0.85);color:white;}
.gallery-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:32px;}
.gallery-note{font-size:14px;color:rgba(255,255,255,0.4);}
.gallery-cta{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--orange);text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:8px;}
.gallery-cta::after{content:'→';}

/* PRICING */
.pricing-section{background:var(--off-white);padding:100px 80px;}
.pricing-intro{margin-bottom:64px;}
.pricing-intro-sub{font-size:17px;color:var(--gray);max-width:560px;line-height:1.7;margin-top:12px;}
.lifetime-banner{display:flex;align-items:center;gap:16px;background:var(--black);border-left:4px solid var(--wood-light);padding:20px 28px;border-radius:0 4px 4px 0;margin-top:28px;max-width:600px;}
.lifetime-banner-text{font-size:15px;color:var(--white);line-height:1.6;}
.lifetime-banner-text strong{color:var(--wood-light);}
.lifetime-icon{font-size:24px;flex-shrink:0;}

.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--light-gray);border-radius:8px;overflow:hidden;}
.price-card{padding:44px 36px;border-right:1px solid var(--light-gray);position:relative;background:var(--white);transition:all 0.25s;}
.price-card:last-child{border-right:none;}
.price-card.featured{background:var(--black);border-right:1px solid rgba(255,255,255,0.1);}
.price-card.signature-card{background:var(--cream);}

.price-tier-tag{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:12px;display:block;}
.price-card:not(.featured):not(.signature-card) .price-tier-tag{color:var(--gray);}
.price-card.featured .price-tier-tag{color:var(--orange);}
.price-card.signature-card .price-tier-tag{color:var(--tx-red);}

.price-name{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:2px;margin-bottom:4px;}
.price-card:not(.featured):not(.signature-card) .price-name{color:var(--black);}
.price-card.featured .price-name{color:var(--white);}
.price-card.signature-card .price-name{color:var(--black);}

.price-tagline{font-size:13px;line-height:1.5;margin-bottom:24px;min-height:40px;}
.price-card:not(.featured) .price-tagline{color:var(--gray);}
.price-card.featured .price-tagline{color:rgba(255,255,255,0.5);}

.price-amount-row{display:flex;align-items:baseline;gap:4px;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid;}
.price-card:not(.featured):not(.signature-card) .price-amount-row{border-color:var(--light-gray);}
.price-card.featured .price-amount-row{border-color:rgba(255,255,255,0.1);}
.price-card.signature-card .price-amount-row{border-color:var(--light-gray);}
.price-currency{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--orange);}
.price-amount{font-family:'Bebas Neue',sans-serif;font-size:72px;line-height:1;color:var(--orange);}
.price-card.signature-card .price-currency,.price-card.signature-card .price-amount{color:var(--tx-red);}

.price-features{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:36px;}
.price-features li{font-size:14px;display:flex;align-items:flex-start;gap:10px;line-height:1.4;}
.price-card:not(.featured) .price-features li{color:var(--black);}
.price-card.featured .price-features li{color:rgba(255,255,255,0.8);}
.price-features li::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px;}
.price-card:not(.featured):not(.signature-card) .price-features li::before{background:var(--gray);}
.price-card.featured .price-features li::before{background:var(--orange);}
.price-card.signature-card .price-features li::before{background:var(--tx-red);}
.price-features li.highlight{font-weight:600;}
.price-card.featured .price-features li.highlight{color:var(--orange);}
.price-card.signature-card .price-features li.highlight{color:var(--tx-red);}
.price-features li.dim{opacity:0.4;}

.price-who{font-size:13px;font-style:italic;padding:14px 16px;border-radius:4px;margin-bottom:28px;}
.price-card:not(.featured):not(.signature-card) .price-who{background:var(--off-white);color:var(--gray);}
.price-card.featured .price-who{background:rgba(245,166,35,0.08);color:rgba(255,255,255,0.5);}
.price-card.signature-card .price-who{background:rgba(191,10,48,0.06);color:var(--gray);}

.btn-price{width:100%;padding:16px;border-radius:4px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:700;font-size:14px;letter-spacing:0.5px;transition:all 0.2s;border:none;}
.btn-price-plain{background:var(--light-gray);color:var(--black);}
.btn-price-plain:hover{background:#D0C8BC;}
.btn-price-featured{background:var(--orange);color:var(--black);}
.btn-price-featured:hover{background:var(--orange-dark);}
.btn-price-signature{background:var(--tx-red);color:var(--white);}
.btn-price-signature:hover{background:#9a0825;}

/* LOGO PICKER */
.logo-picker{margin:24px 0;}
.logo-picker-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--tx-red);text-transform:uppercase;margin-bottom:12px;display:block;}
.logo-options{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.logo-opt{border:1.5px solid var(--light-gray);border-radius:6px;padding:10px 6px;text-align:center;cursor:pointer;transition:all 0.2s;background:white;}
.logo-opt:hover,.logo-opt.active{border-color:var(--tx-red);background:#FFF5F7;}
.logo-opt svg{width:32px;height:32px;display:block;margin:0 auto 4px;}
.logo-opt-label{font-size:9px;color:var(--gray);letter-spacing:1px;text-transform:uppercase;font-family:'DM Mono',monospace;}

/* REFILL NOTE */
.refill-note{margin-top:40px;display:flex;align-items:center;justify-content:center;gap:16px;padding:20px;border:1px dashed var(--light-gray);border-radius:4px;}
.refill-note-text{font-size:14px;color:var(--gray);}
.refill-note-text strong{color:var(--black);}
.refill-pill{background:var(--black);color:var(--orange);font-family:'DM Mono',monospace;font-size:11px;letter-spacing:1.5px;padding:6px 16px;border-radius:20px;white-space:nowrap;}

/* WHY */
.why-section{background:var(--off-white);}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:64px;}
.why-card{border:1px solid var(--light-gray);border-radius:4px;padding:36px 28px;background:var(--white);transition:all 0.25s;position:relative;overflow:hidden;}
.why-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform 0.3s;}
.why-card:hover::after{transform:scaleX(1);}
.why-card:hover{transform:translateY(-4px);}
.why-card.wood-card::after{background:var(--wood-mid);}
.why-icon{width:52px;height:52px;background:var(--cream);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.why-card.wood-card .why-icon{background:#FFF0DC;}
.why-title{font-weight:700;font-size:17px;margin-bottom:10px;}
.why-desc{font-size:14px;color:var(--gray);line-height:1.75;}

/* REVIEWS */
.reviews-section{background:var(--cream);padding:100px 80px;}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px;}
.review-card{background:var(--white);border:1px solid var(--light-gray);border-radius:4px;padding:32px;}
.review-stars{color:var(--orange);font-size:16px;letter-spacing:2px;margin-bottom:16px;}
.review-text{font-size:15px;line-height:1.7;color:var(--black);margin-bottom:24px;font-style:italic;}
.review-author{font-weight:700;font-size:14px;}
.review-location{font-size:12px;color:var(--gray);margin-top:2px;}
.review-pkg{display:inline-block;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:3px 10px;border-radius:20px;margin-top:8px;}
.pkg-basic-badge{background:#F1EFE8;color:var(--gray);}
.pkg-complete-badge{background:#FFF3D9;color:var(--orange-dark);}
.pkg-sig-badge{background:#FFF0F2;color:var(--tx-red);}

/* ORDER */
.order-section{background:var(--off-white);}
.order-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:64px;}
.order-step{padding:0 28px;border-right:1px solid var(--light-gray);position:relative;}
.order-step:last-child{border-right:none;}
.order-step-num{font-family:'Bebas Neue',sans-serif;font-size:96px;color:var(--orange);opacity:0.12;line-height:1;position:absolute;top:-20px;left:20px;}
.order-step-content{position:relative;padding-top:64px;}
.order-step-title{font-weight:700;font-size:16px;margin-bottom:8px;}
.order-step-desc{font-size:14px;color:var(--gray);line-height:1.7;}

/* CTA BANNER */
.cta-banner{background:var(--orange);padding:80px;display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,4vw,60px);color:var(--black);line-height:1;letter-spacing:1px;}
.cta-sub{font-size:16px;color:rgba(0,0,0,0.55);margin-top:8px;}
.btn-dark{background:var(--black);color:var(--white);border:none;padding:20px 48px;border-radius:2px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:16px;cursor:pointer;white-space:nowrap;transition:all 0.2s;text-decoration:none;display:inline-block;}
.btn-dark:hover{background:#333;transform:translateY(-2px);}

/* FOOTER */
footer{background:var(--black);color:var(--white);padding:64px 80px 40px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px;}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:3px;color:var(--orange);margin-bottom:16px;}
.footer-tagline{font-size:14px;color:rgba(255,255,255,0.4);line-height:1.7;max-width:260px;}
.footer-col-title{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:20px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:12px;}
.footer-links a{font-size:14px;color:rgba(255,255,255,0.6);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:var(--orange);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:32px;display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.3);}
.footer-made{font-family:'DM Mono',monospace;font-size:11px;color:rgba(255,255,255,0.2);}

/* REVEAL ANIMATION */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.6s ease,transform 0.6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ===== CHECKOUT OVERLAY ===== */
.co-overlay{
  display:none;position:fixed;inset:0;z-index:200;
  background:var(--off-white);overflow-y:auto;
  animation:coSlideIn 0.35s cubic-bezier(.4,0,.2,1);
}
.co-overlay.open{display:block;}
@keyframes coSlideIn{from{transform:translateY(40px);opacity:0;}to{transform:translateY(0);opacity:1;}}

.co-nav{
  position:sticky;top:0;z-index:10;
  background:var(--black);border-bottom:2px solid var(--orange);
  padding:0 40px;height:64px;
  display:flex;align-items:center;justify-content:space-between;
}
.co-logo{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:3px;color:var(--orange);}
.co-logo span{color:white;}
.co-back{
  font-size:13px;color:rgba(255,255,255,0.55);
  background:none;border:none;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;transition:color 0.2s;
}
.co-back:hover{color:var(--orange);}
.co-secure{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:1.5px;color:rgba(255,255,255,0.3);}

.co-progress{background:white;border-bottom:1px solid var(--light-gray);padding:14px 40px;}
.co-progress-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;}
.co-pstep{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--gray);}
.co-pstep.active{color:var(--orange);}
.co-pdot{width:24px;height:24px;border-radius:50%;border:2px solid var(--light-gray);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;background:white;}
.co-pstep.active .co-pdot{border-color:var(--orange);color:var(--orange);}
.co-pline{flex:1;height:1.5px;background:var(--light-gray);margin:0 8px;}

.co-wrap{max-width:1080px;margin:0 auto;padding:48px 40px 80px;display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:start;}

/* Form sections */
.co-section{margin-bottom:32px;}
.co-section-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:1.5px;margin-bottom:18px;padding-bottom:10px;border-bottom:2px solid var(--light-gray);display:flex;align-items:center;gap:10px;}
.co-section-num{width:26px;height:26px;border-radius:50%;background:var(--orange);color:var(--black);font-family:'Bebas Neue',sans-serif;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.co-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.co-field-row.single{grid-template-columns:1fr;}
.co-field{display:flex;flex-direction:column;gap:5px;}
.co-field label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray);}
.co-field label .req{color:var(--orange);margin-left:2px;}
.co-field input,.co-field select,.co-field textarea{
  height:46px;padding:0 14px;border:1.5px solid var(--light-gray);border-radius:6px;
  font-family:'DM Sans',sans-serif;font-size:15px;color:var(--black);
  background:white;transition:border-color 0.2s,box-shadow 0.2s;outline:none;
  -webkit-appearance:none;appearance:none;
}
.co-field textarea{height:80px;padding:12px 14px;resize:none;line-height:1.5;}
.co-field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A7265' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;
}
.co-field input:focus,.co-field select:focus,.co-field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(245,166,35,0.12);}
.co-field input.co-err{border-color:#C0392B !important;box-shadow:0 0 0 3px rgba(192,57,43,0.1) !important;}
.co-hint{font-size:11px;color:var(--gray);margin-top:3px;}

/* House number special */
.co-num-input input{
  font-family:'Bebas Neue',sans-serif;font-size:38px;letter-spacing:4px;
  text-align:center;height:68px;border-color:var(--wood-mid);background:#FFFBF5;
}
.co-num-input input:focus{border-color:var(--wood-dark);box-shadow:0 0 0 3px rgba(160,104,42,0.15);}
.co-curb-preview{margin-top:12px;background:#9A9490;border-radius:6px;padding:14px;text-align:center;}
.co-curb-white{background:white;border-radius:3px;padding:10px 24px;display:inline-flex;align-items:center;gap:14px;}
.co-curb-num{font-family:'Bebas Neue',sans-serif;font-size:44px;color:var(--black);letter-spacing:5px;line-height:1;min-width:60px;}
.co-curb-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:rgba(255,255,255,0.4);text-align:center;margin-top:6px;text-transform:uppercase;}

/* Logo picker in checkout */
.co-logo-section{background:var(--cream);border-radius:8px;padding:18px;border:1.5px solid var(--light-gray);margin-top:16px;}
.co-logo-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--tx-red);margin-bottom:12px;display:block;}
.co-logo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.co-logo-opt{border:1.5px solid var(--light-gray);border-radius:6px;padding:10px 6px;text-align:center;cursor:pointer;transition:all 0.2s;background:white;}
.co-logo-opt:hover,.co-logo-opt.picked{border-color:var(--tx-red);background:#FFF5F7;}
.co-logo-opt svg{width:32px;height:32px;display:block;margin:0 auto 4px;}
.co-logo-opt-lbl{font-size:9px;color:var(--gray);letter-spacing:1px;text-transform:uppercase;font-family:'DM Mono',monospace;}

/* Delivery */
.co-delivery-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.co-del-opt{border:1.5px solid var(--light-gray);border-radius:8px;padding:14px;cursor:pointer;transition:all 0.2s;background:white;display:flex;gap:10px;align-items:flex-start;}
.co-del-opt.active{border-color:var(--orange);background:#FFFBF2;}
.co-del-opt input[type=radio]{accent-color:var(--orange);margin-top:2px;flex-shrink:0;}
.co-del-name{font-weight:700;font-size:13px;margin-bottom:2px;}
.co-del-sub{font-size:11px;color:var(--gray);}
.co-del-price{font-weight:700;font-size:13px;color:var(--orange);margin-left:auto;flex-shrink:0;}

/* Payment placeholder */
.co-payment-box{border:2px dashed var(--light-gray);border-radius:8px;padding:28px;text-align:center;background:white;}
.co-payment-icon{font-size:28px;margin-bottom:10px;}
.co-payment-title{font-weight:700;font-size:15px;margin-bottom:6px;}
.co-payment-sub{font-size:13px;color:var(--gray);line-height:1.6;max-width:280px;margin:0 auto 14px;}
.co-square-badge{display:inline-flex;align-items:center;gap:8px;background:var(--black);color:white;padding:7px 14px;border-radius:4px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1.5px;}

/* Order Summary */
.co-summary{position:sticky;top:88px;}
.co-sum-box{background:white;border:1px solid var(--light-gray);border-radius:12px;overflow:hidden;}
.co-sum-hd{background:var(--black);padding:18px 22px;}
.co-sum-hd-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;color:var(--orange);}
.co-sum-hd-sub{font-size:11px;color:rgba(255,255,255,0.4);margin-top:2px;}
.co-sum-pkg{padding:18px 22px;border-bottom:1px solid var(--light-gray);}
.co-sum-pkg-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
.co-sum-pkg-name{font-weight:700;font-size:15px;}
.co-sum-pkg-desc{font-size:12px;color:var(--gray);margin-top:3px;line-height:1.4;}
.co-sum-pkg-price{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--orange);white-space:nowrap;}
.co-sum-items{padding:14px 22px;border-bottom:1px solid var(--light-gray);}
.co-sum-item{display:flex;align-items:flex-start;gap:8px;padding:5px 0;font-size:12px;color:var(--gray);}
.co-sum-item::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--light-gray);flex-shrink:0;margin-top:5px;}
.co-sum-item.hl{color:var(--black);font-weight:600;}
.co-sum-item.hl::before{background:var(--wood-mid);}
.co-sum-preview{padding:14px 22px;background:#FFFBF5;border-bottom:1px solid var(--light-gray);}
.co-sum-preview-lbl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--wood-mid);margin-bottom:8px;display:block;text-transform:uppercase;}
.co-mini-curb{background:#9A9490;border-radius:4px;padding:10px;text-align:center;}
.co-mini-curb-inner{background:white;border-radius:2px;padding:8px 18px;display:inline-flex;align-items:center;gap:8px;}
.co-mini-num{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--black);letter-spacing:4px;line-height:1;}
.co-mini-empty{font-size:12px;color:#ccc;letter-spacing:2px;}
.co-sum-totals{padding:14px 22px;border-bottom:1px solid var(--light-gray);}
.co-total-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--gray);}
.co-total-row .co-tv{font-weight:600;color:var(--black);}
.co-total-row.free .co-tv{color:#2A6B2A;font-weight:700;}
.co-total-row.grand{font-size:17px;font-weight:700;color:var(--black);padding-top:10px;margin-top:6px;border-top:1.5px solid var(--light-gray);}
.co-total-row.grand .co-tv{color:var(--orange);font-family:'Bebas Neue',sans-serif;font-size:26px;}
.co-sum-guarantee{padding:14px 22px;display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid var(--light-gray);}
.co-guarantee-txt{font-size:11px;color:var(--gray);line-height:1.5;}
.co-guarantee-txt strong{color:var(--black);display:block;margin-bottom:2px;}
.co-sum-submit{padding:18px 22px;}
.co-btn-order{
  width:100%;padding:16px;background:var(--orange);color:var(--black);
  border:none;border-radius:6px;font-family:'DM Sans',sans-serif;
  font-weight:700;font-size:15px;cursor:pointer;transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.co-btn-order:hover{background:var(--orange-dark);transform:translateY(-1px);}
.co-btn-order:disabled{background:var(--light-gray);color:var(--gray);cursor:not-allowed;transform:none;}
.co-spinner{display:none;width:16px;height:16px;border:2px solid rgba(0,0,0,0.2);border-top-color:var(--black);border-radius:50%;animation:spin 0.7s linear infinite;}
.co-btn-order.loading .co-spinner{display:block;}
.co-btn-order.loading .co-btn-lbl{display:none;}
@keyframes spin{to{transform:rotate(360deg);}}
.co-secure-note{text-align:center;font-size:10px;color:var(--gray);margin-top:8px;font-family:'DM Mono',monospace;letter-spacing:1px;}

/* Success screen */
.co-success{display:none;text-align:center;padding:60px 40px;max-width:520px;margin:0 auto;}
.co-success.show{display:block;}
.co-success-icon{width:70px;height:70px;border-radius:50%;background:#EAF3EA;border:2px solid #2A6B2A;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:30px;}
.co-success-title{font-family:'Bebas Neue',sans-serif;font-size:48px;margin-bottom:10px;}
.co-success-sub{font-size:15px;color:var(--gray);line-height:1.7;margin-bottom:24px;}
.co-success-order{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:2px;color:var(--orange);background:var(--cream);padding:10px 20px;border-radius:4px;display:inline-block;margin-bottom:28px;}
.co-success-steps{text-align:left;background:white;border:1px solid var(--light-gray);border-radius:8px;padding:22px;margin:0 auto 28px;}
.co-sst{display:flex;gap:12px;margin-bottom:14px;font-size:13px;color:var(--gray);}
.co-sst:last-child{margin-bottom:0;}
.co-sst-n{width:22px;height:22px;border-radius:50%;background:var(--orange);color:var(--black);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.co-btn-home{background:var(--black);color:white;border:none;padding:14px 36px;border-radius:4px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:14px;cursor:pointer;transition:background 0.2s;}
.co-btn-home:hover{background:#333;}

/* FAQ */
.faq-section{background:var(--off-white);}
.faq-list{max-width:780px;margin-top:56px;display:flex;flex-direction:column;gap:0;}
.faq-item{border-bottom:1px solid var(--light-gray);}
.faq-item:first-child{border-top:1px solid var(--light-gray);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:22px 0;background:none;border:none;cursor:pointer;text-align:left;
  font-family:'DM Sans',sans-serif;font-size:16px;font-weight:600;color:var(--black);
  transition:color 0.2s;
}
.faq-q:hover{color:var(--orange);}
.faq-q.open{color:var(--orange);}
.faq-icon{
  font-size:22px;font-weight:300;color:var(--orange);flex-shrink:0;
  transition:transform 0.25s;line-height:1;
}
.faq-q.open .faq-icon{transform:rotate(45deg);}
.faq-a{
  display:none;padding:0 0 22px 0;
}
.faq-a.open{display:block;}
.faq-a p{font-size:15px;color:var(--gray);line-height:1.8;}
.faq-a strong{color:var(--black);}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  nav{padding:0 24px;}
  .nav-links{display:none;}
  .hero{grid-template-columns:1fr;}
  .hero-right{display:none;}
  .hero-left{padding:60px 32px;}
  section{padding:64px 32px;}
  .wood-banner{padding:40px 32px;grid-template-columns:1fr;}
  .wood-divider{display:none;}
  .how-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:1fr;}
  .gallery-item:first-child{grid-column:span 1;}
  .pricing-grid{grid-template-columns:1fr;}
  .price-card{border-right:none;border-bottom:1px solid var(--light-gray);}
  .price-card.featured{border-bottom:1px solid rgba(255,255,255,0.1);}
  .why-grid{grid-template-columns:1fr 1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .order-steps{grid-template-columns:1fr 1fr;gap:32px;}
  .order-step{border-right:none;border-bottom:1px solid var(--light-gray);padding-bottom:32px;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .cta-banner{flex-direction:column;text-align:center;padding:60px 32px;}
  footer{padding:60px 32px 32px;}
  .logo-options{grid-template-columns:repeat(4,1fr);}
  .co-wrap{grid-template-columns:1fr;padding:24px 20px 60px;}
  .co-summary{position:static;}
  .co-field-row{grid-template-columns:1fr;}
  .co-delivery-opts{grid-template-columns:1fr;}
  .co-logo-grid{grid-template-columns:repeat(4,1fr);}
}
