/* LogHomeMart prototype design system — ported from docs/mockups/loghomemart_redesign.html */
:root{
  --timber:#2B221A;--timber-2:#3D3127;--pine:#2F5233;--pine-dark:#24402A;--pine-tint:#E9F0E7;
  --cedar:#B4683E;--paper:#FFF;--warm:#F3EEE5;--warm-2:#EAE2D4;--ink:#2B221A;--muted:#6E6257;
  --line:#E2D9CB;--radius:10px;--shadow:0 2px 14px rgba(43,34,26,.10);
  --display:'Bitter',Georgia,serif;--body:'Public Sans',-apple-system,'Segoe UI',sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.55;font-size:16px}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
:focus-visible{outline:3px solid var(--cedar);outline-offset:2px;border-radius:4px}

/* value bar */
.valuebar{background:var(--pine);color:#fff;font-size:13.5px}
.valuebar .wrap{display:flex;gap:22px;justify-content:center;align-items:center;padding:8px 20px;flex-wrap:wrap}
.valuebar span{display:flex;align-items:center;gap:7px;white-space:nowrap}
.valuebar .check{color:#BCD9A8;font-weight:700}
.valuebar a{color:#fff;font-weight:700;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.45)}
.valuebar small{opacity:.75;font-size:11.5px}
@media(max-width:700px){.valuebar span:nth-child(3){display:none}}

/* header + nav */
header{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60}
.topline{display:flex;align-items:center;gap:18px;padding:14px 0}
.logo{font-family:var(--display);font-weight:800;font-size:24px;letter-spacing:-.3px;text-decoration:none;line-height:1.1}
.logo b{color:var(--pine)}
.logo small{display:block;font-family:var(--body);font-weight:600;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.search{flex:1;display:flex;max-width:520px;position:relative}
.search input{flex:1;border:1.5px solid var(--line);border-right:none;border-radius:8px 0 0 8px;padding:10px 14px;font:inherit;font-size:14.5px;min-width:0}
.search button{border:none;background:var(--pine);color:#fff;padding:0 16px;border-radius:0 8px 8px 0;cursor:pointer;font-size:16px}
.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--line);border-radius:0 0 10px 10px;box-shadow:var(--shadow);max-height:340px;overflow:auto;display:none;z-index:70}
.search-results a{display:block;padding:9px 14px;text-decoration:none;font-size:14px;border-bottom:1px solid var(--warm)}
.search-results a:hover{background:var(--warm)}
.search-results .sr-type{color:var(--muted);font-size:11.5px;margin-left:6px}
.hdr-actions{display:flex;align-items:center;gap:14px;margin-left:auto}
.hdr-call{display:flex;flex-direction:column;line-height:1.15;text-decoration:none;text-align:right}
.hdr-call em{font-style:normal;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.hdr-call strong{font-size:16px;color:var(--pine)}
.burger{display:none;background:none;border:1.5px solid var(--line);border-radius:8px;padding:8px 11px;font-size:18px;cursor:pointer}
nav.mainnav{border-top:1px solid var(--line)}
nav.mainnav>ul{display:flex;gap:4px;list-style:none;justify-content:center}
nav.mainnav>ul>li{position:relative}
nav.mainnav>ul>li>a{display:block;padding:11px 16px;text-decoration:none;font-weight:600;font-size:14.5px;border-bottom:3px solid transparent}
nav.mainnav>ul>li>a:hover{border-bottom-color:var(--pine);color:var(--pine)}
nav.mainnav a.sale{color:var(--cedar)}
.navhint{font-size:11px;font-weight:600;color:var(--muted);display:block;letter-spacing:.02em}
.dropdown{position:absolute;top:100%;left:0;min-width:280px;background:#fff;border:1.5px solid var(--line);border-radius:0 0 10px 10px;box-shadow:var(--shadow);padding:10px 0;display:none;z-index:65}
nav.mainnav li:hover .dropdown,nav.mainnav li:focus-within .dropdown{display:block}
.dropdown a{display:block;padding:8px 18px;text-decoration:none;font-size:14px}
.dropdown a:hover{background:var(--warm);color:var(--pine)}
@media(max-width:880px){
  .search{display:none}.hdr-call em{display:none}.burger{display:block}
  nav.mainnav{display:none}nav.mainnav.open{display:block}
  nav.mainnav>ul{flex-direction:column;gap:0;padding:6px 0}
  .dropdown{position:static;display:block;border:none;box-shadow:none;padding:0 0 6px 14px}
}

/* hero carousel */
.hero{position:relative;background:var(--timber);color:#fff;overflow:hidden}
.slides{display:flex;transition:transform .55s cubic-bezier(.4,.1,.2,1)}
.slide{min-width:100%;position:relative;min-height:430px;display:flex;align-items:flex-end}
.slide .bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.92)}
.slide::after{content:"";position:absolute;inset:0;background:linear-gradient(15deg,rgba(28,21,15,.86) 18%,rgba(28,21,15,.42) 52%,rgba(28,21,15,.05) 80%)}
.slide .content{position:relative;z-index:2;padding:40px 20px 64px;max-width:1180px;margin:0 auto;width:100%}
.slide .eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#D8E6C8;background:rgba(47,82,51,.65);padding:5px 12px;border-radius:99px;margin-bottom:14px}
.slide h2,.slide h1{font-family:var(--display);font-weight:800;font-size:clamp(28px,4.6vw,46px);line-height:1.08;max-width:620px;margin-bottom:10px}
.slide p{max-width:520px;font-size:clamp(14.5px,1.6vw,17px);color:#EDE6DC;margin-bottom:22px}
.slide .price{font-family:var(--display);font-weight:700;color:#C9DCB0}
.btn{display:inline-block;font:inherit;font-weight:700;font-size:15px;text-decoration:none;border:none;cursor:pointer;border-radius:8px;padding:13px 24px;transition:transform .12s,background .15s}
.btn:active{transform:scale(.97)}
.btn-solid{background:var(--pine);color:#fff}
.btn-solid:hover{background:var(--pine-dark)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.5);margin-left:10px}
.hero-ctrls{position:absolute;bottom:18px;left:0;right:0;z-index:5;display:flex;justify-content:center;gap:10px}
.dot{width:10px;height:10px;border-radius:99px;border:none;background:rgba(255,255,255,.4);cursor:pointer;padding:0;transition:width .25s,background .25s}
.dot.on{background:#fff;width:26px}
.arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(28,21,15,.5);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:20px;width:44px;height:44px;border-radius:99px;cursor:pointer}
.arrow.prev{left:14px}.arrow.next{right:14px}
@media(max-width:700px){.arrow{display:none}.slide{min-height:380px}.btn-ghost{margin-left:0;margin-top:10px}}

.ge-line{background:var(--warm);border-bottom:1px solid var(--line);text-align:center;padding:10px 20px;font-size:13.5px;color:var(--muted)}
.ge-line b{color:var(--ink)}
.ge-line a{color:var(--pine);font-weight:700}

/* sections */
section{padding:58px 0}
.kicker{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--pine);margin-bottom:8px}
h1.sec,h3.sec,h2.sec{font-family:var(--display);font-weight:800;font-size:clamp(24px,3.2vw,34px);line-height:1.12;margin-bottom:8px}
.sec-sub{color:var(--muted);max-width:640px;margin-bottom:30px}
.crumbs{font-size:13px;color:var(--muted);padding:14px 0 0}
.crumbs a{color:var(--pine);text-decoration:none}
.crumbs a:hover{text-decoration:underline}

/* tiles */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tile{position:relative;border:1.5px solid var(--line);border-radius:var(--radius);padding:26px 24px 24px;text-decoration:none;background:var(--paper);transition:box-shadow .18s,transform .18s,border-color .18s;display:flex;flex-direction:column;gap:8px}
.tile:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--pine)}
.tile .ico{width:46px;height:46px;border-radius:99px;background:var(--pine-tint);display:flex;align-items:center;justify-content:center;font-size:21px;margin-bottom:4px}
.tile h4{font-family:var(--display);font-size:20px;font-weight:700}
.tile p{font-size:14px;color:var(--muted)}
.tile .go{margin-top:auto;font-weight:700;font-size:14px;color:var(--pine)}
.tile .go::after{content:" →"}
.tile.hl{border-color:var(--pine);box-shadow:var(--shadow)}
@media(max-width:820px){.tiles{grid-template-columns:1fr}}

/* product cards */
.shop{background:var(--warm)}
.prod-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s,transform .18s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.card .ph{aspect-ratio:1/.85;background:linear-gradient(140deg,#D8CBB6,#BCA98C);position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .tag{position:absolute;top:10px;left:10px;background:var(--cedar);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:6px}
.card .tag.ship{background:var(--pine)}
.card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card h5{font-size:14.5px;font-weight:600;line-height:1.35}
.card h5 a{text-decoration:none}
.card .sku{font-family:var(--mono);font-size:11px;color:var(--muted)}
.card .price-row{margin-top:auto;display:flex;align-items:baseline;gap:8px}
.card .p{font-family:var(--display);font-weight:700;font-size:18px}
.card .add{margin-top:10px;width:100%;background:var(--pine);color:#fff;border:none;border-radius:8px;font:inherit;font-weight:700;font-size:14px;padding:10px;cursor:pointer;text-align:center;text-decoration:none;display:block}
.card .add:hover{background:var(--pine-dark)}
.row-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:22px}
.row-head .viewall{font-weight:700;font-size:14.5px;color:var(--pine);text-decoration:none;white-space:nowrap}
@media(max-width:980px){.prod-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.prod-row{grid-template-columns:1fr 1fr;gap:12px}.card h5{font-size:13px}.card .p{font-size:16px}}

/* PDP */
.pdp{display:grid;grid-template-columns:1.1fr 1fr;gap:38px;align-items:start}
.pdp .gallery img{border-radius:var(--radius);border:1px solid var(--line)}
.pdp h1{font-family:var(--display);font-weight:800;font-size:clamp(22px,2.8vw,32px);line-height:1.15;margin-bottom:8px}
.pdp .orig-title{font-size:12.5px;color:var(--muted);font-family:var(--mono);margin-bottom:14px}
.pdp .price{font-family:var(--display);font-weight:800;font-size:28px;color:var(--pine);margin:10px 0}
.pdp select,.pdp input[type=number]{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;font:inherit;font-size:15px;margin:6px 0 14px}
.pdp label{font-weight:700;font-size:13.5px}
.pdp .btn{width:100%;text-align:center;margin-bottom:10px}
.pdp .call-row{text-align:center;font-size:14px;color:var(--muted);margin-bottom:18px}
.pdp .call-row a{color:var(--pine);font-weight:700}
.freight-note{background:var(--pine-tint);border:1.5px solid var(--pine);border-radius:var(--radius);padding:14px 16px;font-size:14px;margin-bottom:16px}
.desc{margin-top:38px;max-width:820px}
.desc h2{font-family:var(--display);margin-bottom:10px}
.desc :is(p,li){font-size:15px;margin-bottom:9px}
.desc ul{padding-left:20px}
@media(max-width:880px){.pdp{grid-template-columns:1fr}}

/* calculators */
.calc-box{display:grid;grid-template-columns:1.05fr 1fr;gap:0;border:1.5px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.calc-form{padding:30px 28px;background:var(--paper)}
.calc-form label{display:block;font-weight:700;font-size:13.5px;margin:14px 0 6px}
.calc-form label:first-of-type{margin-top:0}
.calc-form input,.calc-form select{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;font:inherit;font-size:15px}
.calc-form .two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.calc-result{background:var(--pine);color:#fff;padding:30px 28px;display:flex;flex-direction:column;justify-content:center}
.calc-result .lbl{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#BCD9A8;margin-bottom:6px}
.calc-result .big{font-family:var(--display);font-weight:800;font-size:clamp(38px,5vw,54px);line-height:1}
.calc-result .unit{font-size:16px;font-weight:600;color:#D9E4CC;margin-bottom:16px}
.calc-result .meta{font-size:13.5px;color:#CFE0BE;border-top:1px solid rgba(255,255,255,.25);padding-top:14px;line-height:1.7}
.calc-result .btn{margin-top:18px;background:#fff;color:var(--pine);align-self:flex-start}
.calc-note{font-size:12.5px;color:var(--muted);margin-top:12px}
@media(max-width:820px){.calc-box{grid-template-columns:1fr}}

/* blog */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.post-card{border:1.5px solid var(--line);border-radius:var(--radius);padding:22px;text-decoration:none;display:flex;flex-direction:column;gap:8px;transition:box-shadow .18s,border-color .18s}
.post-card:hover{box-shadow:var(--shadow);border-color:var(--pine)}
.post-card .pc-cat{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cedar)}
.post-card h4{font-family:var(--display);font-size:18px;line-height:1.25}
.post-card p{font-size:13.5px;color:var(--muted)}
.post-card.cornerstone{background:var(--pine-tint);border-color:var(--pine)}
@media(max-width:820px){.post-grid{grid-template-columns:1fr}}
article.post{max-width:760px;margin:0 auto}
article.post .lead p{font-size:17px;margin-bottom:14px}
article.post h2{font-family:var(--display);margin:26px 0 10px}
.toc{background:var(--warm);border-radius:var(--radius);padding:20px 24px;margin:24px 0}
.toc h3{font-family:var(--display);font-size:16px;margin-bottom:8px}
.toc li{margin:5px 0 5px 18px;font-size:14.5px}
.toc .todo{color:var(--muted)}
.cta-box{background:var(--pine);color:#fff;border-radius:14px;padding:26px 28px;margin:30px 0;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.cta-box .t{flex:1;min-width:220px}
.cta-box h3{font-family:var(--display);margin-bottom:4px}
.cta-box p{font-size:14px;color:#D9E4CC}
.cta-box .btn{background:#fff;color:var(--pine);white-space:nowrap}
.stub-note{font-size:12.5px;color:var(--muted);border:1px dashed var(--line);border-radius:8px;padding:10px 14px;margin-top:26px}

/* FAQ */
.faq-group{max-width:820px;margin:0 auto 26px}
.faq-group h2{font-family:var(--display);margin-bottom:12px}
details{border:1.5px solid var(--line);border-radius:var(--radius);margin-bottom:10px;background:var(--paper)}
summary{padding:15px 18px;font-weight:700;cursor:pointer;font-size:15px}
details p{padding:0 18px 16px;font-size:14.5px;color:#4a4138}

/* calendar */
.cal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.cal-card{border:1.5px solid var(--line);border-radius:var(--radius);padding:22px}
.cal-card.now{border-color:var(--pine);background:var(--pine-tint)}
.cal-card h3{font-family:var(--display);margin-bottom:10px}
.cal-card li{margin:8px 0 8px 18px;font-size:14.5px}
.cal-card a{color:var(--pine);font-weight:600}
@media(max-width:820px){.cal-grid{grid-template-columns:1fr}}
@media print{header,.valuebar,.sticky-call,footer,.email-band,.no-print{display:none!important}.cal-grid{grid-template-columns:1fr 1fr}body{font-size:12px}}

/* trust + email band */
.trust{background:var(--warm)}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.t-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.t-card .big-ico{font-size:26px;margin-bottom:10px}
.t-card h4{font-family:var(--display);font-size:18px;margin-bottom:6px}
.t-card p{font-size:14px;color:var(--muted)}
.t-card a{color:var(--pine);font-weight:700}
@media(max-width:820px){.trust-grid{grid-template-columns:1fr}}
.email-band{background:var(--timber);color:#fff;padding:54px 0}
.email-flex{display:flex;gap:34px;align-items:center;flex-wrap:wrap}
.email-flex .txt{flex:1;min-width:260px}
.email-flex h3{font-family:var(--display);font-size:clamp(22px,3vw,30px);margin-bottom:8px}
.email-flex p{color:#D9D0C3;font-size:15px}
.email-form{display:flex;gap:10px;flex:1;min-width:280px}
.email-form input{flex:1;border:none;border-radius:8px;padding:13px 15px;font:inherit;font-size:15px;min-width:0}
.email-ok{display:none;background:var(--pine);border-radius:8px;padding:13px 18px;font-weight:700}

/* footer */
footer{background:#221B14;color:#CFC5B8;padding:46px 0 26px;font-size:14px}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1fr;gap:26px;margin-bottom:30px}
footer h6{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
footer ul{list-style:none}
footer li{margin-bottom:8px}
footer a{text-decoration:none}
footer a:hover{color:#fff;text-decoration:underline}
.f-bottom{border-top:1px solid #3A3128;padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:#9A8D7D}
@media(max-width:880px){.f-grid{grid-template-columns:1fr 1fr}}

/* sticky call + popup + questionnaire */
.sticky-call{display:none;position:fixed;bottom:16px;left:16px;right:16px;z-index:80;background:var(--pine);color:#fff;text-decoration:none;text-align:center;font-weight:800;font-size:16px;padding:15px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.3)}
@media(max-width:700px){.sticky-call{display:block}body{padding-bottom:74px}}
.overlay{position:fixed;inset:0;background:rgba(28,21,15,.62);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.overlay.show{display:flex}
.modal{background:var(--paper);border-radius:14px;max-width:430px;width:100%;padding:32px 30px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.modal .close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted)}
.modal h4{font-family:var(--display);font-size:23px;line-height:1.2;margin-bottom:8px}
.modal p{font-size:14.5px;color:var(--muted);margin-bottom:16px}
.modal input{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:12px 14px;font:inherit;margin-bottom:10px}
.modal .btn{width:100%}
.modal .no-thanks{display:block;text-align:center;margin-top:12px;font-size:13px;color:var(--muted);background:none;border:none;cursor:pointer;text-decoration:underline}
.quiz{background:var(--pine-tint);border:1.5px solid var(--pine);border-radius:14px;padding:24px 26px;margin:26px auto;max-width:1140px}
.quiz h3{font-family:var(--display);font-size:20px;margin-bottom:4px}
.quiz p{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.quiz .q-opts{display:flex;gap:10px;flex-wrap:wrap}
.quiz button{font:inherit;font-weight:700;font-size:14px;border:1.5px solid var(--pine);background:#fff;color:var(--pine);border-radius:99px;padding:10px 18px;cursor:pointer}
.quiz button:hover{background:var(--pine);color:#fff}
.quiz .q-dismiss{border:none;background:none;color:var(--muted);text-decoration:underline;font-weight:400;font-size:12.5px}
.profile-chip{background:var(--warm);border:1px solid var(--line);border-radius:99px;padding:6px 14px;font-size:12.5px;color:var(--muted);display:inline-flex;gap:8px;align-items:center;margin:10px 0}
.profile-chip button{border:none;background:none;color:var(--pine);cursor:pointer;font-size:12.5px;text-decoration:underline}
