/* ReadyLine Cabinets Co — shared stylesheet
   Brand: steel navy + safety orange + cool paper white, industrial cut-sheet aesthetic */
:root{
  --ink:#16243B; --ink2:#1E2F4D; --paper:#F6F7F5; --card:#FFFFFF;
  --line:#D8DDD9; --slate:#5B6573; --accent:#FF7A1A; --accent-d:#E26405;
  --ok:#1E7F4F; --foot:#0F1A2C; --hi:#FFF4EA;
  --disp:'Archivo',sans-serif; --body:'Inter',sans-serif; --mono:'IBM Plex Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
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;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}
h1,h2,h3,h4{font-family:var(--disp);font-weight:800;line-height:1.05;letter-spacing:-.015em}
section{padding:80px 0}
.eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-d);display:flex;align-items:center;gap:10px}
.eyebrow::after{content:"";flex:0 0 42px;height:1px;background:var(--ink);opacity:.35}
.eyebrow.light{color:var(--accent)}
.eyebrow.light::after{background:#fff;opacity:.3}
.sec-head{max-width:50rem;margin-bottom:44px}
.sec-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:14px 0 12px}
.sec-head p{color:var(--slate);font-size:1.05rem}
.btn{display:inline-block;font-family:var(--disp);font-weight:700;font-size:.95rem;letter-spacing:.01em;cursor:pointer;border:none;padding:14px 26px;transition:transform .15s ease,background .15s ease,color .15s ease}
.btn-orange{background:var(--accent);color:#1A1206}
.btn-orange:hover{background:var(--accent-d);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-ghost.light{color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.6)}
.btn-ghost.light:hover{background:#fff;color:var(--ink)}
.btn-sm{padding:10px 18px;font-size:.85rem}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- utility bar ---------- */
.util{background:var(--ink);color:#E9EDF3;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.util b{color:var(--accent)}
@media(max-width:640px){.util .right{display:none}}

/* ---------- nav ---------- */
nav{position:sticky;top:0;z-index:50;background:rgba(246,247,245,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:var(--disp);font-weight:900;font-stretch:115%;font-size:1.3rem;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.logo .tick{width:14px;height:14px;background:var(--accent);clip-path:polygon(0 0,100% 0,100% 100%)}
.logo span{color:var(--slate);font-weight:500;font-stretch:100%;font-size:.78rem;letter-spacing:.12em;margin-left:2px}
.navlinks{display:flex;gap:28px;align-items:center}
.navlinks a:not(.btn){font-size:.92rem;font-weight:500;color:var(--ink2)}
.navlinks a:not(.btn):hover,.navlinks a.active{color:var(--accent-d)}
@media(max-width:920px){.navlinks a:not(.btn){display:none}}

/* ---------- hero (generic) ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,21,33,.92) 0%,rgba(15,21,33,.74) 42%,rgba(15,21,33,.30) 100%)}
.hero .wrap{position:relative;z-index:1;padding:96px 24px}
.hero.tall .wrap{padding:130px 24px}
.hero h1{font-size:clamp(2.4rem,5vw,3.8rem);font-stretch:108%;max-width:18ch}
.hero h1 .price{color:var(--accent)}
.hero p.lede{margin:20px 0 28px;font-size:1.1rem;color:#D6DCE6;max-width:36rem}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero .states{margin-top:30px;font-family:var(--mono);font-size:.76rem;letter-spacing:.1em;color:#9FB0C6}
.hero .states b{color:#fff}

/* ---------- trust strip ---------- */
.strip{background:var(--ink);color:#fff}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.strip .cell{padding:24px 20px;border-left:1px solid rgba(255,255,255,.12)}
.strip .cell:first-child{border-left:none}
.strip .num{font-family:var(--disp);font-weight:800;font-size:1.5rem;color:var(--accent)}
.strip .cap{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:#ADBACB;text-transform:uppercase;margin-top:4px}
@media(max-width:760px){.strip .wrap{grid-template-columns:repeat(2,1fr)}.strip .cell:nth-child(3){border-left:none}}

/* ---------- lines / cards ---------- */
.lines{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.linecard{background:var(--card);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.linecard:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(22,36,59,.12)}
.linecard .pic{aspect-ratio:16/10;overflow:hidden;position:relative}
.linecard .pic img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.linecard:hover .pic img{transform:scale(1.04)}
.linecard .pic .band{position:absolute;left:0;top:0;height:7px;width:100%}
.lc-pad{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.lc-code{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;color:var(--slate)}
.linecard h3{font-size:1.4rem;margin:8px 0 10px;font-stretch:106%}
.linecard p{font-size:.92rem;color:var(--slate)}
.lc-foot{margin-top:auto;padding-top:20px;display:flex;justify-content:space-between;align-items:center}
.lc-from{font-family:var(--mono);font-size:.74rem;color:var(--slate)}
.lc-from b{display:block;font-family:var(--disp);font-size:1.3rem;color:var(--ink)}
@media(max-width:980px){.lines{grid-template-columns:1fr;max-width:520px;margin:0 auto}}

/* ---------- split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split.rev .txt{order:2}
.split .pic{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line)}
.split .pic img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:clamp(1.7rem,3vw,2.3rem);margin:12px 0 14px}
.split p{color:var(--slate);margin-bottom:14px}
.split ul{list-style:none;margin:16px 0 22px;font-family:var(--mono);font-size:.84rem}
.split ul li{padding:9px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:18px}
.split ul li span:last-child{color:var(--ink);font-weight:600;text-align:right}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:26px}.split.rev .txt{order:0}}

/* ---------- finishes ---------- */
.fin-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.fin{background:var(--card);border:1px solid var(--line)}
.fin .sw{aspect-ratio:3/2;border-bottom:1px solid var(--line)}
.fin .nm{padding:12px 14px}
.fin .nm b{display:block;font-family:var(--disp);font-size:.98rem}
.fin .nm small{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}
@media(max-width:860px){.fin-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.fin-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- category grid ---------- */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{background:var(--card);border:1px solid var(--line);padding:22px 22px 24px;transition:border-color .15s ease}
.cat:hover{border-color:var(--accent)}
.cat .k{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;color:var(--accent-d);font-weight:600}
.cat h4{font-size:1.12rem;margin:8px 0 8px}
.cat p{font-size:.86rem;color:var(--slate)}
.cat .skus{margin-top:12px;font-family:var(--mono);font-size:.7rem;color:var(--slate);letter-spacing:.04em}
@media(max-width:860px){.cats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cats{grid-template-columns:1fr}}

/* ---------- spec table ---------- */
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);background:var(--card)}
table.spec{width:100%;border-collapse:collapse;font-size:.9rem}
.spec th,.spec td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
.spec thead th{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);border-bottom:2px solid var(--ink)}
.spec td.r,.spec th.r{text-align:right;font-family:var(--mono)}
.spec tbody tr:hover{background:var(--hi)}
.spec tfoot td{padding:14px 16px;font-weight:700;border-top:2px solid var(--ink);font-family:var(--mono)}
.spec tfoot td.r{color:var(--accent-d)}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{border-top:3px solid var(--ink);padding-top:18px}
.step .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--accent-d);font-weight:600}
.step h3{font-size:1.1rem;margin:8px 0 8px}
.step p{font-size:.9rem;color:var(--slate)}
@media(max-width:860px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* ---------- callout band w/ image ---------- */
.callout{position:relative;color:#fff;overflow:hidden;background:var(--ink)}
.callout .bg{position:absolute;inset:0;z-index:0;opacity:.28}
.callout .bg img{width:100%;height:100%;object-fit:cover}
.callout .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.callout h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:14px}
.callout p{color:#C7D0DC;max-width:34rem}
.callout .nums{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.callout .nums .n{font-family:var(--disp);font-weight:800;font-size:2rem;color:var(--accent)}
.callout .nums .l{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:#ADBACB;text-transform:uppercase;margin-top:2px}
@media(max-width:860px){.callout .wrap{grid-template-columns:1fr;gap:26px}}

/* ---------- compare table ---------- */
.cmp-scroll{overflow-x:auto}
table.cmp{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--card);border:1px solid var(--line)}
.cmp th,.cmp td{padding:15px 16px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);border-bottom:2px solid var(--ink)}
.cmp .rl{background:var(--hi);border-left:3px solid var(--accent);font-weight:600}
.cmp td.y{color:var(--ok);font-weight:600}
.cmp td.n{color:#B23B3B}

/* ---------- cta band ---------- */
.band{background:var(--accent);color:#1A1206}
.band .wrap{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.band h2{font-size:clamp(1.6rem,3vw,2.3rem)}
.band p{font-weight:500;margin-top:4px}
.band .btn{background:var(--ink);color:#fff}
.band .btn:hover{background:#0D1626}

/* ---------- service area ---------- */
.area{background:var(--ink);color:#fff}
.area .sec-head p{color:#ADBACB}
.stgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.st{border:1px solid rgba(255,255,255,.16);padding:24px 22px}
.st .ab{font-family:var(--disp);font-weight:900;font-size:2rem;color:var(--accent)}
.st .nm{font-weight:600;margin:2px 0 10px}
.st .dt{font-family:var(--mono);font-size:.74rem;color:#ADBACB;line-height:1.7}
@media(max-width:860px){.stgrid{grid-template-columns:repeat(2,1fr)}}

/* ---------- faq ---------- */
.faq{max-width:820px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{cursor:pointer;font-family:var(--disp);font-weight:700;font-size:1.05rem;padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--accent-d);font-size:1.3rem}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--slate);padding:0 0 18px;font-size:.95rem}

/* ---------- downloads ---------- */
.dls{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.dl{background:var(--card);border:1px solid var(--line);padding:22px;display:flex;flex-direction:column;gap:8px}
.dl .ic{width:38px;height:38px;background:var(--ink);color:var(--accent);font-family:var(--mono);font-weight:600;font-size:.7rem;display:flex;align-items:center;justify-content:center}
.dl h4{font-size:1.08rem}
.dl p{font-size:.85rem;color:var(--slate);flex:1}
.dl a{font-family:var(--mono);font-size:.78rem;font-weight:600;color:var(--accent-d);letter-spacing:.04em}
@media(max-width:860px){.dls{grid-template-columns:1fr}}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.cform label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin:14px 0 6px}
.cform input,.cform textarea,.cform select{width:100%;padding:12px 14px;border:1px solid var(--line);background:var(--card);font-family:var(--body);font-size:.95rem;color:var(--ink)}
.cform textarea{min-height:110px;resize:vertical}
.cinfo .row{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--line)}
.cinfo .row .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);width:90px;flex:0 0 90px}
.cinfo .row .v{font-weight:500}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:26px}}

/* ---------- footer ---------- */
footer{background:var(--foot);color:#8FA0B6;padding:54px 0 38px;font-size:.88rem}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px}
footer .logo{color:#fff}
footer h4{color:#fff;font-size:.8rem;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
footer a{display:block;margin:7px 0}
footer a:hover{color:var(--accent)}
.foot-note{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:20px;font-family:var(--mono);font-size:.7rem;letter-spacing:.06em}
@media(max-width:860px){footer .wrap{grid-template-columns:1fr 1fr}}

/* page intro band (interior pages) */
.pintro{background:var(--ink);color:#fff;padding:54px 0}
.pintro .crumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:#9FB0C6;text-transform:uppercase;margin-bottom:12px}
.pintro .crumb a:hover{color:var(--accent)}
.pintro h1{font-size:clamp(2rem,4vw,3rem)}
.pintro p{color:#C7D0DC;max-width:42rem;margin-top:12px}
