/*
Theme Name: Coco Design
Description: Custom boutique interior design theme for Coco Design — Oakville & GTA.
Author: Coco Design
Version: 1.0.0
Text Domain: coco-design
*/

:root {
  --white:#FFFFFF;--off:#F7F5F2;--ink:#141414;
  --muted:#8A8480;--gold:#B8925A;--border:#E4E0DB;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--ink);background:var(--white);
  font-size:15px;line-height:1.7;overflow-x:hidden;font-weight:300;}
img{display:block;width:100%;height:100%;object-fit:cover;}
a{text-decoration:none;color:inherit;}

/* NAV */
.site-header{position:fixed;top:0;left:0;right:0;z-index:200;height:70px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);
  border-bottom:1px solid transparent;transition:border-color .4s;}
.site-header.scrolled{border-color:var(--border);}
.nav-inner{width:100%;max-width:1400px;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  position:relative;}
.nav-left{display:flex;align-items:center;gap:36px;flex:1;}
.nav-right{display:flex;align-items:center;gap:36px;flex:1;justify-content:flex-end;}
.nav-link{font-size:11px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink);transition:color .2s;}
.nav-link:hover,.nav-link.active{color:var(--gold);}
.logo{position:absolute;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;line-height:1;text-decoration:none;}
.logo img{height:38px;width:auto;display:block;}
.footer-brand .logo img, .slide-nav-head .logo img{height:34px;}
.nav-has-drop{position:relative;}
.nav-drop{position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:var(--white);border:1px solid var(--border);min-width:220px;
  opacity:0;pointer-events:none;transition:opacity .2s;padding-top:16px;}
.nav-drop::before{content:'';position:absolute;top:0;left:0;right:0;height:16px;}
.nav-has-drop:hover .nav-drop{opacity:1;pointer-events:auto;}
.nav-drop a{display:block;padding:10px 20px;font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;font-weight:500;color:var(--ink);
  border-bottom:1px solid var(--border);transition:color .2s;}
.nav-drop a:last-child{border-bottom:none;}
.nav-drop a:hover{color:var(--gold);}
.nav-cta{padding:9px 16px;border:1px solid var(--ink);transition:all .2s;white-space:nowrap;}
.nav-cta:hover{background:var(--ink);color:var(--white);}
.hamburger{display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:24px;height:1px;background:var(--ink);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}
.nav-overlay{display:none;}
.slide-nav{display:none;}
.nav-mobile-right{display:none;}

/* HERO */
.hero{position:relative;width:100%;height:100vh;min-height:600px;
  overflow:hidden;margin-top:70px;}
.hero img{position:absolute;inset:0;}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.22);}
.hero-text{position:absolute;bottom:80px;left:80px;color:#fff;max-width:560px;}
.hero-eye{font-size:10px;letter-spacing:3px;text-transform:uppercase;
  opacity:.7;margin-bottom:16px;display:block;}
.hero-title{font-family:var(--serif);font-size:clamp(52px,7vw,96px);
  font-weight:300;line-height:1.0;margin-bottom:28px;}
.hero-title em{font-style:italic;}

/* BUTTONS */
.btn{display:inline-block;font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:600;padding:13px 28px;transition:all .25s;}
.btn-light{border:1px solid rgba(255,255,255,.7);color:#fff;}
.btn-light:hover{background:#fff;color:var(--ink);}
.btn-dark{border:1px solid var(--ink);color:var(--ink);}
.btn-dark:hover{background:var(--ink);color:var(--white);}
.btn-gold{border:1px solid var(--gold);color:var(--gold);}
.btn-gold:hover{background:var(--gold);color:var(--white);}

/* LAYOUT */
.section{padding:100px 0;}
.container{max-width:1200px;margin:0 auto;padding:0 60px;}
.container-wide{max-width:1400px;margin:0 auto;padding:0 40px;}
.eyebrow{font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--muted);display:block;margin-bottom:20px;}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.1;}
h2{font-size:clamp(36px,4vw,56px);}
h3{font-size:clamp(22px,2.5vw,34px);}
p{font-size:15px;line-height:1.8;color:#555;font-weight:300;}
.lead{font-size:18px;line-height:1.7;font-family:var(--serif);font-weight:300;color:var(--ink);}

/* SPLIT */
.split{display:grid;grid-template-columns:1fr 1fr;}
.split-img{position:relative;min-height:560px;overflow:hidden;}
.split-text{display:flex;flex-direction:column;justify-content:center;
  padding:80px;background:var(--off);}
.split-text-inner{max-width:460px;}
.split-text h2{margin-bottom:24px;}
.split-text p{margin-bottom:28px;}

/* PORTFOLIO GRID */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;}
.port-item{position:relative;aspect-ratio:3/4;overflow:hidden;display:block;}
.port-item img{transition:transform .6s ease;}
.port-item:hover img{transform:scale(1.04);}
.port-overlay{position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.6) 0%, rgba(0,0,0,.15) 45%, rgba(0,0,0,0) 75%);
  transition:background .4s;display:flex;flex-direction:column;
  justify-content:flex-end;padding:24px;}
.port-item:hover .port-overlay{background:linear-gradient(to top, rgba(0,0,0,.7) 0%, rgba(0,0,0,.25) 50%, rgba(0,0,0,0) 80%);}
.port-name{font-family:var(--serif);font-size:22px;font-style:italic;
  font-weight:300;color:#fff;transform:translateY(0);
  transition:transform .35s;}
.port-loc{font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.85);margin-top:4px;}
.port-item:hover .port-name{transform:translateY(-4px);}

/* PULL QUOTE */
.pull-quote{padding:100px 60px;text-align:center;}
.pull-quote blockquote{font-family:var(--serif);font-size:clamp(28px,3.5vw,48px);
  font-weight:300;font-style:italic;line-height:1.25;max-width:800px;
  margin:0 auto 24px;color:var(--ink);}
.pull-quote cite{font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);font-style:normal;}

/* PROJECT */
.proj-title-block{padding:136px 0 48px;}
.proj-intro-grid{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;}
.proj-meta-item{margin-bottom:28px;}
.proj-meta-item .label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);display:block;margin-bottom:6px;}
.proj-meta-item .val{font-family:var(--serif);font-size:18px;color:var(--ink);}
.proj-body h3{margin-bottom:20px;}
.proj-body p{margin-bottom:18px;}
.img-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3px;}
.img-grid-2 .tall{aspect-ratio:3/4;overflow:hidden;}
.img-grid-3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3px;height:560px;}
.img-grid-3>*:first-child{grid-row:span 2;}
.img-full{width:100%;aspect-ratio:16/9;overflow:hidden;}

/* SERVICE / ABOUT PAGES */
.page-title-block{padding:136px 0 64px;border-bottom:1px solid var(--border);}
.process-steps{}
.process-step{display:grid;grid-template-columns:80px 1fr;gap:40px;
  padding:48px 0;border-bottom:1px solid var(--border);align-items:start;}
.process-step:last-child{border-bottom:none;}
.step-num{font-family:var(--serif);font-size:48px;font-weight:300;
  color:var(--border);line-height:1;}
.step-content h3{margin-bottom:12px;}
.step-content p{max-width:600px;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;}
.about-img{aspect-ratio:3/4;overflow:hidden;}
.values-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;}
.value-item h4{font-family:var(--serif);font-size:22px;font-weight:400;
  margin-bottom:12px;font-style:italic;}
.value-item p{font-size:14px;}
.service-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:start;padding:80px 0;}
.service-intro p{margin-bottom:16px;}

/* CTA BAND */
.cta-band{padding:100px 60px;text-align:center;background:var(--ink);color:#fff;}
.cta-band .eyebrow{color:rgba(255,255,255,.4);}
.cta-band h2{color:#fff;margin-bottom:16px;}
.cta-band p{color:rgba(255,255,255,.5);max-width:480px;margin:0 auto 40px;}

/* QUOTE FORM */
.quote-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 70px);margin-top:70px;}
.quote-left{background:var(--ink);color:#fff;padding:80px 60px;
  display:flex;flex-direction:column;justify-content:center;}
.quote-left h2{color:#fff;margin-bottom:20px;}
.quote-left p{color:rgba(255,255,255,.55);margin-bottom:32px;}
.trust-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px;}
.trust-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);
  margin-top:7px;flex-shrink:0;}
.trust-item p{color:rgba(255,255,255,.6);font-size:14px;margin:0;}
.quote-right{background:var(--off);padding:80px 60px;
  display:flex;flex-direction:column;justify-content:center;}
.quote-right h3{margin-bottom:32px;}
.form-group{margin-bottom:24px;}
.form-label{display:block;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500;}
.form-input{width:100%;padding:14px 0;border:none;border-bottom:1px solid var(--border);
  background:transparent;font-family:var(--sans);font-size:15px;font-weight:300;
  color:var(--ink);outline:none;transition:border-color .2s;}
.form-input:focus{border-color:var(--ink);}
.form-input::placeholder{color:var(--muted);}
textarea.form-input{resize:none;height:100px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.btn-submit{width:100%;padding:16px;background:var(--ink);color:#fff;
  border:none;font-family:var(--sans);font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .2s;
  margin-top:8px;}
.btn-submit:hover{background:#333;}

/* FOOTER */
.site-footer{background:var(--off);padding:64px 0 40px;border-top:1px solid var(--border);}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 60px;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.8;
  max-width:240px;margin-top:16px;}
.footer-col h5{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--ink);margin-bottom:20px;font-weight:600;}
.footer-col a{display:block;font-size:13px;color:var(--muted);
  margin-bottom:10px;transition:color .2s;font-weight:300;}
.footer-col a:hover{color:var(--ink);}
.footer-bottom{max-width:1200px;margin:40px auto 0;padding:20px 60px 0;
  border-top:1px solid var(--border);display:flex;justify-content:space-between;}
.footer-bottom p{font-size:12px;color:var(--muted);}

/* FADE */
.fade-up{opacity:0;transform:translateY(24px);
  transition:opacity .7s ease,transform .7s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* RESPONSIVE */
@media(max-width:1024px){
  .nav-left,.nav-right{display:none;}
  .nav-mobile-right{display:flex;justify-content:flex-end;flex:1;}
  .logo{position:static;transform:none;}
  .hamburger{display:flex;}
  .nav-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,0);
    z-index:149;pointer-events:none;transition:background .4s;}
  .nav-overlay.open{background:rgba(0,0,0,.5);pointer-events:auto;}
  .slide-nav{display:flex;position:fixed;top:0;right:0;bottom:0;width:300px;
    background:var(--white);z-index:150;flex-direction:column;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);
    padding:80px 40px 40px;border-left:1px solid var(--border);overflow-y:auto;}
  .slide-nav.open{transform:translateX(0);}
  .slide-nav a{display:block;font-size:12px;letter-spacing:2px;
    text-transform:uppercase;font-weight:500;padding:13px 0;
    border-bottom:1px solid var(--border);color:var(--ink);transition:color .2s;}
  .slide-nav a:hover{color:var(--gold);}
  .slide-nav .sub-links a{font-size:11px;padding:9px 0 9px 16px;
    letter-spacing:1.5px;color:var(--muted);}
  .split,.about-grid,.quote-wrap{grid-template-columns:1fr;}
  .split-img{min-height:400px;}
  .split-text{padding:48px 32px;}
  .port-grid{grid-template-columns:1fr 1fr;}
  .proj-intro-grid{grid-template-columns:1fr;gap:40px;}
  .footer-inner{grid-template-columns:1fr 1fr;gap:40px;}
  .values-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .quote-left{padding:60px 40px;}
  .quote-right{padding:60px 40px;}
  .service-intro{grid-template-columns:1fr;gap:32px;padding:48px 0;}
  .about-grid{grid-template-columns:1fr;gap:48px;}
  .quote-wrap{grid-template-columns:1fr;}
}
@media(max-width:680px){
  .container,.container-wide{padding:0 24px;}
  .hero-text{left:24px;bottom:48px;right:24px;}
  .port-grid{grid-template-columns:1fr;}
  .img-grid-2{grid-template-columns:1fr;}
  .img-grid-3{grid-template-columns:1fr;height:auto;}
  .img-grid-3>*:first-child{grid-row:span 1;}
  .footer-inner{grid-template-columns:1fr;gap:28px;}
  .values-grid{grid-template-columns:1fr;}
  .section{padding:64px 0;}
  .process-step{grid-template-columns:48px 1fr;gap:24px;}
  .step-num{font-size:32px;}
  .pull-quote{padding:64px 24px;}
  .cta-band{padding:64px 24px;}
  .form-grid{grid-template-columns:1fr;}
}

/* SERVICE PAGE GALLERY */
.service-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px;}
.service-gallery .port-item{aspect-ratio:3/4;}

/* PROJECT HERO */
.phero { position: relative; height: 88vh; min-height: 520px; overflow: hidden; margin-top: 70px; }
.phero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.phero-overlay { position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,.1) 0%, rgba(0,0,0,.45) 100%); }
.phero-text { position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; text-align: center; color: #fff; padding: 0 24px; }
.phero-text .eyebrow { color: rgba(255,255,255,.65); }
.phero-text h1 { font-family: var(--serif); font-size: clamp(48px,7vw,96px);
  font-weight: 300; font-style: italic; line-height: 1.05; }
.proj-desc { max-width: 720px; margin: 0 auto; text-align: center; }
.proj-desc p { font-size: 16px; line-height: 1.9; }
.proj-facts { display: flex; justify-content: center; gap: 56px; margin-top: 40px; flex-wrap: wrap; }
.proj-fact { text-align: center; }
.proj-fact .label { font-size: 10px; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--muted); display: block; margin-bottom: 6px; }
.proj-fact .val { font-family: var(--serif); font-size: 17px; font-style: italic; color: var(--ink); }
.service-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;}
.service-gallery .port-item{aspect-ratio:3/4;}
.more-projects { background: var(--off); }

/* TABS */
.port-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 48px; }
.port-tab { font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase;
  font-weight: 500; padding: 16px 32px; cursor: pointer; color: var(--muted);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color .2s, border-color .2s; background: none; border: none; font-family: var(--sans); }
.port-tab:hover { color: var(--ink); }
.port-tab.active { color: var(--ink); border-bottom-color: var(--gold); }
.port-panel { display: none; }
.port-panel.active { display: block; }
.port-label { font-family: var(--serif); font-size: 13px; font-style: italic;
  color: var(--muted); margin-bottom: 40px; font-weight: 300; }

/* FAST FORM */
.fast-form-band { background: var(--off); padding: 80px 0; border-top: 1px solid var(--border); }
.fast-form-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start;
  max-width: 1100px; margin: 0 auto; padding: 0 60px; }
.fast-form-intro h2 { margin-bottom: 16px; }
.fast-form-intro p { max-width: 380px; }
.ff-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ff-group { margin-bottom: 20px; }
.ff-label { display: block; font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--muted); margin-bottom: 6px; font-weight: 500; }
.ff-input { width: 100%; padding: 12px 0; border: none; border-bottom: 1px solid var(--border);
  background: transparent; font-family: var(--sans); font-size: 15px; font-weight: 300;
  color: var(--ink); outline: none; transition: border-color .2s; }
.ff-input:focus { border-color: var(--ink); }
textarea.ff-input { resize: none; height: 80px; }
.ff-submit { padding: 14px 36px; background: var(--ink); color: #fff; border: none;
  font-family: var(--sans); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase;
  font-weight: 600; cursor: pointer; transition: background .2s; margin-top: 4px; }
.ff-submit:hover { background: #333; }

/* FAQ */
.faq-section { padding: 100px 0; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 28px 0; background: none; border: none; cursor: pointer; text-align: left;
  font-family: var(--serif); font-size: 20px; font-weight: 400; color: var(--ink); gap: 24px; }
.faq-q:hover { color: var(--gold); }
.faq-icon { font-family: var(--sans); font-size: 22px; font-weight: 300; color: var(--gold);
  transition: transform .3s; flex-shrink: 0; line-height: 1; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-a p { padding: 0 48px 28px 0; font-size: 15px; }
.faq-item.open .faq-a { max-height: 300px; }

/* PRICING / PACKAGE */
.package-band { background: var(--ink); color: #fff; padding: 80px 60px; text-align: center; }
.package-band .eyebrow { color: var(--gold); }
.package-band h2 { color: #fff; }
.package-price { font-family: var(--serif); font-size: clamp(48px,6vw,80px);
  font-weight: 300; font-style: italic; color: var(--gold); margin: 24px 0 8px; }
.package-band p { color: rgba(255,255,255,.6); max-width: 480px; margin: 0 auto; }
.steps-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 48px; }
.benefit-list { max-width: 640px; margin: 0 auto; }
.benefit-item { display: flex; gap: 16px; align-items: flex-start; padding: 18px 0;
  border-bottom: 1px solid var(--border); }
.benefit-item:last-child { border-bottom: none; }
.benefit-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold);
  margin-top: 9px; flex-shrink: 0; }
.benefit-item p { margin: 0; font-size: 15px; }

@media(max-width:1024px){
  .fast-form-grid{grid-template-columns:1fr;gap:40px;padding:0 40px;}
  .steps-3{grid-template-columns:1fr;gap:32px;}
  .service-gallery{grid-template-columns:1fr 1fr;}
  .values-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .img-grid-3{grid-template-columns:1fr 1fr;height:auto;}
  .img-grid-3>*:first-child{grid-row:span 1;grid-column:span 2;}
}
@media(max-width:680px){
  .service-gallery{grid-template-columns:1fr;}
  .ff-row{grid-template-columns:1fr;}
  .fast-form-grid{padding:0 24px;}
  .faq-q{font-size:17px;}
  .phero{height:60vh;min-height:420px;}
  .phero-text h1{font-size:clamp(36px,10vw,64px);}
  .proj-facts{gap:24px 32px;}
  .proj-fact .val{font-size:15px;}
  .proj-desc p{font-size:15px;}
  .proj-intro-grid{gap:32px;}
  .package-price{font-size:clamp(36px,10vw,56px);}
}
