/* =====================================================================
   라온홈 커튼&블라인드 — style.css  (고급 커스텀 에디토리얼 리디자인)
   테라코타(#c2583f) · 크림(#f7f1e8) · 딥브라운(#4a3528)
   8px 그리드 spacing · 디스플레이 타이포 · 비대칭 레이아웃
   인라인 SVG · 시스템 폰트 · 외부 리소스 0 · 모바일 퍼스트
   ===================================================================== */

:root{
  /* 색 */
  --terra:#c2583f; --terra-dk:#a8472f; --terra-soft:#d98a6a; --terra-tint:#fbeee7;
  --cream:#f7f1e8; --cream-2:#f1e4d4; --cream-3:#faf5ee;
  --brown:#4a3528; --brown-2:#5a4334; --brown-soft:#7a6353;
  --ink:#3a2c22; --line:#e8dcc9; --line-2:#efe6d6;
  --white:#fffdf9; --kakao:#fae100; --kakao-ink:#3a1d1d; --sage:#8aa06a;

  /* 그림자 (따뜻한 톤) */
  --sh-xs:0 1px 3px rgba(74,53,40,.06);
  --sh-sm:0 4px 14px rgba(74,53,40,.08);
  --sh:0 14px 40px rgba(74,53,40,.10);
  --sh-lg:0 28px 64px rgba(74,53,40,.16);
  --sh-terra:0 16px 34px rgba(194,88,63,.26);

  /* 라운드 */
  --r-sm:12px; --r:18px; --r-lg:26px; --r-xl:34px;

  /* 8px 그리드 spacing */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px; --s8:128px;

  /* 타이포 */
  --serif:"Nanum Myeongjo","Apple SD Gothic Neo",ui-serif,Georgia,"Times New Roman",serif;
  --sans:"Pretendard","Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.72;font-size:16px;word-break:keep-all;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;margin:0;padding:0}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{font-family:var(--serif);font-weight:700;color:var(--brown);line-height:1.22;letter-spacing:-.015em}

.shell{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}

:focus-visible{outline:3px solid var(--terra);outline-offset:3px;border-radius:6px}

.skip-link{position:absolute;left:-999px;top:0;z-index:300;background:var(--terra);color:#fff;padding:10px 18px;border-radius:0 0 12px 0}
.skip-link:focus{left:0}

/* ---------- 버튼 ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 24px;border-radius:999px;border:1.5px solid transparent;
  font-weight:700;font-size:15px;letter-spacing:-.01em;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;position:relative;
}
.btn svg{flex:0 0 auto}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn-lg{padding:16px 30px;font-size:16px}
.btn-primary{background:var(--terra);color:#fff;box-shadow:var(--sh-terra)}
.btn-primary:hover{background:var(--terra-dk);box-shadow:0 20px 40px rgba(194,88,63,.34)}
.btn-outline{background:var(--white);color:var(--terra-dk);border-color:var(--terra)}
.btn-outline:hover{background:var(--terra-tint)}
.btn-ghost{background:transparent;color:var(--brown);border-color:rgba(74,53,40,.22)}
.btn-ghost:hover{background:rgba(74,53,40,.05);border-color:var(--brown)}
.btn-kakao{background:var(--kakao);color:var(--kakao-ink)}
.btn-kakao:hover{background:#ecd400}

/* ============================ 헤더 ============================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,241,232,.82);
  backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s,box-shadow .3s;
}
.site-header.is-stuck{border-bottom-color:var(--line);box-shadow:var(--sh-xs);background:rgba(247,241,232,.94)}
.header-inner{display:flex;align-items:center;gap:var(--s3);height:74px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto}
.brand-mark svg{border-radius:13px;box-shadow:var(--sh-sm)}
.brand-text{display:flex;flex-direction:column;line-height:1.04}
.brand-text strong{font-family:var(--serif);font-size:18px;color:var(--brown)}
.brand-text em{font-style:normal;font-size:10px;letter-spacing:.24em;color:var(--terra);font-weight:800;margin-top:2px}

.main-nav{display:none}
.main-nav ul{display:flex;gap:30px}
.main-nav a{font-weight:600;font-size:15px;color:var(--brown-soft);position:relative;padding:8px 0}
.main-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:2px;height:2px;background:var(--terra);border-radius:2px;transition:right .3s var(--ease)}
.main-nav a:hover{color:var(--terra)}
.main-nav a:hover::after{right:0}

.header-actions{display:none;align-items:center;gap:14px}
.header-tel{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:var(--brown)}
.header-tel svg{color:var(--terra)}
.header-tel:hover{color:var(--terra)}
.header-cta{background:var(--brown);color:var(--cream);padding:11px 20px;border-radius:999px;font-weight:700;font-size:14px;box-shadow:var(--sh-sm);transition:transform .2s var(--ease),background .2s}
.header-cta:hover{background:#3a2920;transform:translateY(-2px)}

.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:transparent;border:0;padding:0 11px;margin-left:auto}
.nav-toggle span{height:2.5px;background:var(--brown);border-radius:2px;transition:transform .28s var(--ease),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-nav{border-top:1px solid var(--line);background:var(--cream)}
.mobile-nav ul{display:flex;flex-direction:column;padding:6px 22px 18px}
.mobile-nav a{display:block;padding:14px 6px;font-weight:600;border-bottom:1px solid var(--line);color:var(--brown)}
.mobile-nav a:last-child{border-bottom:0}

/* ============================ 히어로 ============================ */
.hero{position:relative;overflow:hidden;background:linear-gradient(165deg,#fbf6ee 0%,#f4e7d5 55%,#efdcc6 100%);padding-bottom:var(--s5)}
.hero-atmos{position:absolute;inset:0;z-index:0;pointer-events:none}
.atmos-sun{position:absolute;top:-120px;right:-80px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,rgba(255,224,167,.9),rgba(255,224,167,.32) 45%,transparent 70%)}
.atmos-glow{position:absolute;bottom:-160px;left:-120px;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,88,63,.12),transparent 68%)}
.atmos-grain{position:absolute;inset:0;width:100%;height:100%;mix-blend-mode:multiply}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:var(--s5);padding-top:var(--s6);align-items:center}
.hero-copy{max-width:560px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.6);color:var(--terra-dk);
  font-weight:700;font-size:12.5px;letter-spacing:.01em;padding:8px 16px;border-radius:999px;margin:0 0 var(--s3);box-shadow:var(--sh-xs);border:1px solid rgba(194,88,63,.14)}
.eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--terra);box-shadow:0 0 0 4px rgba(194,88,63,.18)}

.hero h1{font-size:clamp(2.5rem,9.5vw,4.6rem);margin:0 0 var(--s3);line-height:1.08;letter-spacing:-.03em}
.h1-line{display:block}
.h1-accent{color:var(--terra);position:relative;display:inline-block}
.h1-accent::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.14em;background:rgba(194,88,63,.16);border-radius:4px;z-index:-1}
.h1-sub{display:inline;font-size:.58em;color:var(--brown-soft);font-weight:700;letter-spacing:-.01em}

.hero-sub{font-size:clamp(1.02rem,3.4vw,1.2rem);color:var(--brown-soft);margin:0 0 var(--s4);max-width:32em}
.hero-sub strong{color:var(--terra-dk);font-weight:700}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:var(--s5)}

.hero-stats{display:flex;gap:var(--s4);flex-wrap:wrap}
.hero-stats div{position:relative;padding-right:var(--s4)}
.hero-stats div+div::before{content:"";position:absolute;left:calc(-1 * var(--s2) - 4px);top:8px;bottom:8px;width:1px;background:var(--line)}
.hero-stats dt{font-size:13px;color:var(--brown-soft);font-weight:600;margin:0}
.hero-stats dd{margin:2px 0 0;font-family:var(--serif);font-size:1.45rem;color:var(--terra-dk);font-weight:700}

/* 히어로 아트 */
.hero-art{position:relative;display:flex;justify-content:center}
.hero-art-frame{position:relative;width:100%;max-width:440px}
.hero-window{width:100%;height:auto;border-radius:var(--r-xl);box-shadow:var(--sh-lg);background:#fff}
.swatch-card{position:absolute;display:flex;align-items:center;gap:10px;background:var(--white);
  border-radius:14px;padding:10px 14px 10px 10px;box-shadow:var(--sh);margin:0;border:1px solid var(--line-2)}
.swatch-card figcaption{display:flex;flex-direction:column;line-height:1.2}
.swatch-card b{font-size:13px;color:var(--brown)}
.swatch-card i{font-style:normal;font-size:11px;color:var(--brown-soft)}
.swatch{width:34px;height:34px;border-radius:9px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.swatch--linen{background:repeating-linear-gradient(45deg,#e9d9c1,#e9d9c1 3px,#ddc8aa 3px,#ddc8aa 6px)}
.swatch--terra{background:linear-gradient(135deg,#d98a6a,#b34d35)}
.swatch-card--1{top:11%;left:-6%;animation:floaty 6s ease-in-out infinite}
.swatch-card--2{bottom:13%;right:-7%;animation:floaty 6s ease-in-out infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* 스크롤 인디케이터 */
.hero-scroll{position:relative;z-index:1;display:none;flex-direction:column;align-items:center;gap:8px;margin:var(--s4) auto 0;width:max-content;color:var(--brown-soft)}
.scroll-track{width:24px;height:38px;border:2px solid rgba(74,53,40,.28);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-dot{width:5px;height:8px;border-radius:3px;background:var(--terra);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%{opacity:0;transform:translateY(11px)}}
.scroll-label{font-size:12px;font-weight:600;letter-spacing:.04em}

/* 신뢰 마퀴 */
.trust-strip{background:var(--brown);color:var(--cream-2);overflow:hidden;padding:14px 0;border-top:3px solid var(--terra)}
.trust-track{display:flex;width:max-content;gap:0;animation:marquee 26s linear infinite}
.trust-track span{font-family:var(--serif);font-size:1.05rem;font-weight:700;white-space:nowrap;padding:0 4px}
.trust-track i{color:var(--terra-soft);font-style:normal;padding:0 18px;font-size:1.1rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================ 섹션 공통 ============================ */
.section{padding:var(--s7) 0;position:relative}
.products{background:var(--white)}
.gallery{background:var(--cream)}
.process{background:linear-gradient(180deg,var(--brown) 0%,#3c2b20 100%);color:var(--cream)}
.reviews{background:var(--cream-3)}
.area{background:var(--white)}
.contact{background:linear-gradient(160deg,var(--cream) 0%,var(--cream-2) 100%)}

.eyebrow{display:flex;align-items:center;gap:10px;color:var(--terra);font-weight:800;letter-spacing:.2em;font-size:12px;margin:0 0 var(--s2)}
.eyebrow-num{font-family:var(--serif);font-size:14px;color:var(--brown-soft);letter-spacing:0;background:var(--cream-2);width:30px;height:30px;display:inline-grid;place-items:center;border-radius:8px}
.process .eyebrow-num{background:rgba(255,255,255,.1);color:var(--cream-2)}
.eyebrow--center{justify-content:center}
.eyebrow--light{color:var(--terra-soft)}

.section-head{margin:0 auto var(--s6);max-width:640px;text-align:center}
.section-head h2{font-size:clamp(1.8rem,5.5vw,2.9rem);margin:0 0 var(--s2)}
.section-desc{color:var(--brown-soft);font-size:1.04rem;margin:0}
.process .section-desc{color:#d8c9b8}

/* 비대칭 split 헤드 */
.section-head--split{display:grid;grid-template-columns:1fr;gap:var(--s2);text-align:left;max-width:none;align-items:end}
.section-head--split h2{font-size:clamp(1.9rem,6vw,3.1rem);margin:0}
.section-lead{color:var(--brown-soft);font-size:1.04rem;margin:0;max-width:30em}

/* ---------- 제품 (비대칭 그리드) ---------- */
.product-grid{display:grid;grid-template-columns:1fr;gap:var(--s3)}
.product-card{
  background:var(--cream-3);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s4) var(--s3);box-shadow:var(--sh-xs);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;position:relative;overflow:hidden;
}
.product-card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(120% 80% at 100% 0%,rgba(217,138,106,.08),transparent 60%);opacity:0;transition:opacity .3s}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:var(--terra-soft)}
.product-card:hover::before{opacity:1}
.product-icon{display:inline-grid;place-items:center;width:72px;height:72px;border-radius:20px;background:var(--white);box-shadow:var(--sh-sm);margin-bottom:var(--s2)}
.product-icon svg{width:50px;height:50px}
.product-card h3{font-size:1.28rem;margin:0 0 var(--s1)}
.product-card p{margin:0;color:var(--brown-soft);font-size:.98rem}

/* 피처 카드 (와이드, 가로 배치) */
.product-card--feature{background:linear-gradient(135deg,#2f2118,#412f22);color:var(--cream);border-color:transparent;display:grid;grid-template-columns:1fr;gap:var(--s3);align-items:center}
.product-card--feature::before{display:none}
.product-card--feature:hover{border-color:transparent}
.product-card--feature h3{color:#fff;font-size:1.7rem}
.product-card--feature p{color:#d9c9b8}
.pc-art svg{border-radius:var(--r);box-shadow:0 12px 30px rgba(0,0,0,.25)}
.pc-tag{display:inline-block;background:var(--terra);color:#fff;font-size:11.5px;font-weight:800;letter-spacing:.04em;padding:5px 12px;border-radius:999px;margin-bottom:12px}

.product-note{display:flex;align-items:flex-start;gap:12px;margin:var(--s5) auto 0;max-width:720px;
  background:var(--cream-2);border-radius:var(--r);padding:var(--s3) var(--s4);color:var(--brown-soft);font-size:1rem;box-shadow:var(--sh-xs)}
.product-note svg{flex:0 0 auto;margin-top:3px}
.product-note strong{color:var(--terra-dk)}

/* ---------- 갤러리 (매거진 매소너리) ---------- */
.gallery-masonry{display:grid;grid-template-columns:1fr;gap:var(--s2)}
.gallery-tile{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);background:var(--cream-2);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.gallery-tile:hover{transform:translateY(-5px) scale(1.008);box-shadow:var(--sh-lg);z-index:2}
.gallery-tile svg,.gallery-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.gallery-tile:hover svg,.gallery-tile:hover img{transform:scale(1.05)}
.gallery-cap{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 14px;color:#fff;display:flex;align-items:center;gap:9px;
  font-weight:600;font-size:.94rem;background:linear-gradient(180deg,transparent,rgba(58,44,34,.72))}
.gallery-cap::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--terra-soft);flex:0 0 auto}

/* ---------- 시공과정 (수직 타임라인) ---------- */
.process-shell{position:relative}
.timeline{position:relative;display:grid;grid-template-columns:1fr;gap:var(--s4);margin-top:var(--s5)}
.timeline::before{content:"";position:absolute;left:27px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--terra) 0%,rgba(217,138,106,.4) 100%)}
.tl-step{position:relative;display:grid;grid-template-columns:56px 1fr;gap:var(--s3);align-items:start;padding-left:0}
.tl-icon{position:relative;z-index:1;width:56px;height:56px;border-radius:50%;background:var(--terra);box-shadow:0 8px 20px rgba(194,88,63,.4),0 0 0 6px rgba(247,241,232,.06);display:grid;place-items:center}
.tl-icon svg{width:40px;height:40px}
.tl-num{position:absolute;left:0;top:-24px;font-family:var(--serif);font-size:.9rem;color:var(--terra-soft);font-weight:700;letter-spacing:.1em;opacity:0}
.tl-body h3{color:#fff;font-size:1.3rem;margin:0 0 6px}
.tl-body p{margin:0;color:#d8c9b8;font-size:.99rem}
.tl-body p strong{color:#fff}

/* ---------- 후기 (비대칭: lead 카드 크게) ---------- */
.review-grid{display:grid;grid-template-columns:1fr;gap:var(--s3)}
.review-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s4) var(--s3);box-shadow:var(--sh-xs);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.review-card--lead{background:linear-gradient(150deg,var(--terra-tint),#fff);border-color:var(--terra-soft)}
.quote-mark{position:absolute;top:8px;right:24px;font-family:var(--serif);font-size:5rem;line-height:1;color:rgba(194,88,63,.16)}
.stars{color:#e8a838;letter-spacing:3px;margin-bottom:12px;font-size:1.1rem}
.review-text{margin:0;color:var(--ink);font-size:1rem}
.review-card--lead .review-text{font-size:1.12rem;line-height:1.75}
.review-by{display:flex;align-items:center;gap:10px;margin:var(--s3) 0 0 !important;font-size:.88rem;color:var(--terra-dk);font-weight:700}
.rb-avatar{width:34px;height:34px;border-radius:50%;background:var(--cream-2);color:var(--terra-dk);font-family:var(--serif);display:grid;place-items:center;font-size:.95rem;flex:0 0 auto;box-shadow:var(--sh-xs)}
.review-note{text-align:center;color:var(--brown-soft);font-size:.84rem;margin:var(--s4) 0 0}

/* ---------- 지역 (비대칭 2단) ---------- */
.area-inner{display:grid;grid-template-columns:1fr;gap:var(--s5);align-items:center}
.area-text h2{font-size:clamp(1.8rem,5.8vw,2.7rem);margin:0 0 var(--s3)}
.area-lead{color:var(--brown-soft);margin:0 0 var(--s3)}
.area-lead strong,.area-text strong{color:var(--terra-dk)}
.area-tags{display:flex;flex-wrap:wrap;gap:9px;margin:0 0 var(--s4)}
.area-tags li{background:var(--cream-2);color:var(--brown);font-weight:600;font-size:.86rem;padding:7px 14px;border-radius:999px;transition:background .2s,color .2s,transform .2s}
.area-tags li:hover{background:var(--terra);color:#fff;transform:translateY(-2px)}
.area-info{margin:0 0 var(--s4);display:grid;gap:12px;border-top:1px solid var(--line);padding-top:var(--s3)}
.area-info div{display:flex;gap:14px;flex-wrap:wrap}
.area-info dt{flex:0 0 80px;color:var(--terra-dk);font-weight:700;font-size:.92rem}
.area-info dd{margin:0;color:var(--ink);font-size:.97rem}
.area-info a{color:var(--terra-dk);font-weight:700}
.area-map{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh);aspect-ratio:13/11;border:1px solid var(--line)}
.map-illust{width:100%;height:100%}
.map-pin-label{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);background:#fff;color:var(--brown);font-weight:700;font-size:.86rem;padding:9px 18px;border-radius:999px;box-shadow:var(--sh-sm);white-space:nowrap}

/* ---------- 상담 (비대칭: aside + form) ---------- */
.contact-inner{display:grid;grid-template-columns:1fr;gap:var(--s4);align-items:start}
.contact-aside h2{font-size:clamp(1.8rem,5.8vw,2.7rem);margin:0 0 var(--s3)}
.contact-lead{color:var(--brown-soft);margin:0 0 var(--s4)}
.contact-quick{display:grid;gap:12px}
.contact-quick a,.contact-quick .cq-static{display:flex;align-items:center;gap:14px;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:14px 18px;box-shadow:var(--sh-xs)}
.contact-quick a{transition:transform .2s var(--ease),box-shadow .2s}
.contact-quick a:hover{transform:translateY(-2px);box-shadow:var(--sh-sm)}
.contact-quick svg{color:var(--terra);flex:0 0 auto}
.contact-quick b{display:block;font-size:12px;color:var(--brown-soft);font-weight:600}
.contact-quick i{font-style:normal;font-weight:700;color:var(--brown);font-size:1rem}

.contact-form{background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);padding:var(--s4) var(--s3);box-shadow:var(--sh);display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.field{display:flex;flex-direction:column;gap:7px}
.field-full{grid-column:1/-1}
.field label{font-weight:700;font-size:.9rem;color:var(--brown)}
.field input,.field select,.field textarea{font-family:inherit;font-size:1rem;color:var(--ink);padding:14px 15px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--cream-3);transition:border-color .2s,box-shadow .2s,background .2s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--terra);background:#fff;box-shadow:0 0 0 3px rgba(194,88,63,.14)}
.field textarea{resize:vertical;min-height:100px}
.form-consent{grid-column:1/-1;margin:0;font-size:.9rem;color:var(--brown-soft)}
.form-consent label{display:flex;gap:10px;align-items:flex-start;cursor:pointer}
.form-consent input{margin-top:4px;width:17px;height:17px;accent-color:var(--terra);flex:0 0 auto}
.form-actions{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.form-actions .btn{flex:1 1 auto;min-width:140px}
.field-error{border-color:var(--terra-dk) !important;box-shadow:0 0 0 3px rgba(168,71,47,.16) !important}

/* ============================ 푸터 ============================ */
.site-footer{background:linear-gradient(180deg,#42301f 0%,#33241a 100%);color:#e9ddce;padding:var(--s6) 0 var(--s4);margin-bottom:66px}
.footer-inner{display:grid;grid-template-columns:1fr;gap:var(--s5)}
.footer-brand .brand-mark{display:inline-block;margin-bottom:14px}
.footer-brand strong{font-family:var(--serif);font-size:1.35rem;color:#fff;display:block}
.footer-en{font-size:10px;letter-spacing:.24em;color:var(--terra-soft);font-weight:800}
.footer-tagline{margin:14px 0 var(--s3);color:#c9b9a6;font-size:.95rem}
.footer-links{display:flex;gap:10px;flex-wrap:wrap}
.footer-links a{color:#e9ddce;font-weight:600;font-size:.9rem;border:1px solid rgba(255,255,255,.16);padding:8px 16px;border-radius:999px;transition:background .2s,border-color .2s}
.footer-links a:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3);color:#fff}
.footer-biz p{margin:0 0 8px;font-size:.9rem;color:#d6c8b8}
.footer-biz .lbl{display:inline-block;min-width:100px;color:var(--terra-soft);font-weight:700}
.footer-biz a{color:#e9ddce}
.footer-biz a:hover{color:#fff;text-decoration:underline}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:var(--s5);padding-top:var(--s3);display:flex;flex-direction:column;gap:8px}
.footer-privacy{margin:0;font-size:.82rem;color:#b8a692}
.footer-copy{margin:0;font-size:.82rem;color:#a8957f}

/* ============================ 모바일 퀵바 ============================ */
.quickbar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:grid;grid-template-columns:repeat(3,1fr);
  background:rgba(255,253,249,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--line);box-shadow:0 -8px 24px rgba(74,53,40,.12);padding-bottom:env(safe-area-inset-bottom)}
.quickbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px;font-size:11px;font-weight:700;color:var(--brown);transition:background .2s}
.quickbar a svg{color:var(--terra)}
.quickbar a:nth-child(3) svg{color:#caa400}
.quickbar a:active{background:var(--cream)}
.quickbar a+a{border-left:1px solid var(--line)}

/* ============================ 모달 ============================ */
.modal{position:fixed;inset:0;z-index:300;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(58,44,34,.55);backdrop-filter:blur(3px);animation:fade .25s ease both}
.modal-box{position:relative;background:var(--white);border-radius:var(--r-xl);padding:var(--s5) var(--s4) var(--s4);max-width:460px;width:100%;box-shadow:var(--sh-lg);text-align:center;animation:pop .28s var(--ease) both}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
.modal-emoji{display:block;font-size:2.4rem;margin-bottom:8px}
.modal-box h3{font-size:1.4rem;margin:0 0 12px}
.modal-box>p{color:var(--brown-soft);margin:0 0 var(--s3)}
.modal-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.modal-actions .btn{flex:1 1 auto;min-width:130px}
.modal-note{margin:var(--s2) 0 0 !important;font-size:.85rem;color:var(--brown-soft)}
.modal-close{position:absolute;top:14px;right:16px;width:38px;height:38px;border:0;border-radius:50%;background:var(--cream);color:var(--brown);font-size:22px;line-height:1;display:grid;place-items:center;transition:background .2s}
.modal-close:hover{background:var(--cream-2)}

/* ============================ 스크롤 진입 애니메이션 ============================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-reveal-delay="1"]{transition-delay:.08s}
.reveal[data-reveal-delay="2"]{transition-delay:.16s}
.reveal[data-reveal-delay="3"]{transition-delay:.24s}
.reveal[data-reveal-delay="4"]{transition-delay:.32s}
.tl-step.is-in .tl-num{opacity:1;transition:opacity .5s ease .2s}

/* ============================ 반응형 ============================ */
@media (min-width:600px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-masonry{grid-template-columns:repeat(2,1fr)}
  .review-grid{grid-template-columns:repeat(2,1fr)}
  .contact-quick{grid-template-columns:1fr 1fr}
}
@media (min-width:760px){
  .hero-grid{grid-template-columns:1.05fr .95fr;gap:var(--s6);padding-top:var(--s7)}
  .hero-scroll{display:flex}
  .section-head--split{grid-template-columns:1.1fr 1fr;gap:var(--s5)}
  .section-head--split .section-lead{justify-self:end;padding-bottom:8px}
  .product-card--feature{grid-template-columns:200px 1fr}
  .timeline{grid-template-columns:1fr 1fr;gap:var(--s5) var(--s6)}
  .timeline::before{display:none}
  .area-inner{grid-template-columns:1.1fr 1fr;gap:var(--s6)}
  .contact-inner{grid-template-columns:.85fr 1.15fr;gap:var(--s5)}
  .footer-inner{grid-template-columns:1.2fr 1.4fr}
}
@media (min-width:960px){
  .main-nav{display:block}
  .header-actions{display:flex}
  .nav-toggle,.mobile-nav,.quickbar{display:none}
  .site-footer{margin-bottom:0}
  html{scroll-padding-top:90px}
  /* 비대칭 제품 그리드: 피처 카드 2칸 차지 */
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .product-card--feature{grid-column:span 2}
  /* 매거진 매소너리: 행마다 다른 리듬 */
  .gallery-masonry{grid-template-columns:repeat(6,1fr);grid-auto-rows:150px}
  .gallery-tile{grid-column:span 2;grid-row:span 2}
  .gallery-tile:nth-child(1){grid-column:span 4;grid-row:span 3}
  .gallery-tile:nth-child(4){grid-row:span 3}
  .gallery-tile:nth-child(5){grid-column:span 4;grid-row:span 2}
  .gallery-tile:nth-child(8){grid-column:span 4;grid-row:span 2}
  .review-grid{grid-template-columns:repeat(3,1fr)}
  .review-card--lead{grid-column:span 1;grid-row:span 2}
  .section{padding:var(--s8) 0}
}
@media (min-width:1100px){
  .review-grid{grid-template-columns:1.3fr 1fr 1fr}
}

/* prefers-reduced-motion 존중 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1 !important;transform:none !important}
  .trust-track,.swatch-card--1,.swatch-card--2,.scroll-dot{animation:none !important}
  .btn:hover,.product-card:hover,.gallery-tile:hover,.review-card:hover{transform:none}
}
