/* ============ SRI RAMA 108 — editorial design system ============ */
:root{
  --bg:#FAFAF6;
  --ink:#141412;
  --muted:#6E6C64;
  --line:#E4E1D6;
  --accent:#E8590C;
  --dark:#121210;
  --dark-soft:#1C1B18;
  --max:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.disp{font-family:'Space Grotesk',sans-serif;font-weight:500;line-height:1.05;letter-spacing:-.02em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(var(--max),92%);margin:0 auto}
section{padding:104px 0}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}
.rv1{transition-delay:.08s}.rv2{transition-delay:.16s}.rv3{transition-delay:.24s}

/* ---------- nav ---------- */
header{position:fixed;inset:0 0 auto;z-index:90;transition:.35s}
header.on{background:rgba(250,250,246,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
header.inv:not(.on){color:#fff}
.navbar{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;letter-spacing:.01em;display:flex;align-items:center;gap:10px}
.brand i{font-style:normal;display:inline-grid;place-items:center;width:30px;height:30px;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700}
.menu{display:flex;gap:30px;font-size:.82rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}
.menu a{opacity:.6;transition:.2s;padding:4px 0;border-bottom:2px solid transparent}
.menu a:hover{opacity:1}
.menu a.act{opacity:1;border-color:var(--accent)}
.cta{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:12px 22px;background:var(--ink);color:#fff;transition:.25s}
header.inv:not(.on) .cta{background:#fff;color:var(--ink)}
.cta:hover{background:var(--accent);color:#fff}
@media(max-width:920px){.menu{display:none}}
.burger{display:none;width:44px;height:44px;border:1px solid currentColor;background:transparent;color:inherit;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;margin-left:14px}
.burger i{width:20px;height:2px;background:currentColor;display:block;transition:.3s}
header.open .burger i:nth-child(1){transform:translateY(7px) rotate(45deg)}
header.open .burger i:nth-child(2){opacity:0}
header.open .burger i:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.m-panel{display:none;position:fixed;top:76px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);padding:14px 4% 22px;z-index:89;flex-direction:column}
header.open .m-panel{display:flex}
.m-panel a{padding:15px 6px;border-bottom:1px solid var(--line);font-family:'Space Grotesk',sans-serif;font-size:1.05rem;color:var(--ink)!important;opacity:1!important;letter-spacing:0;text-transform:none}
.m-panel a:last-child{border-bottom:0}
@media(max-width:920px){.burger{display:flex}}
@media(max-width:560px){.cta{display:none}.brand span{display:none}}

/* ---------- type utilities ---------- */
.eyebrow{display:flex;align-items:center;gap:14px;font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.eyebrow::before{content:"";width:40px;height:2px;background:var(--accent)}
.h-xl{font-size:clamp(2.6rem,6vw,5rem)}
.h-lg{font-size:clamp(2rem,4vw,3.2rem)}
.h-md{font-size:clamp(1.4rem,2.2vw,1.8rem)}
.sub{color:var(--muted);font-weight:300;font-size:1.05rem;max-width:58ch}
.num{font-family:'Space Grotesk',sans-serif;color:transparent;-webkit-text-stroke:1.5px var(--line);font-size:clamp(4rem,9vw,8rem);font-weight:700;line-height:1}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 30px;font-weight:600;font-size:.86rem;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--ink);transition:.25s;cursor:pointer;background:transparent}
.btn .ar{transition:transform .25s}
.btn:hover .ar{transform:translateX(6px)}
.btn-solid{background:var(--ink);color:#fff}
.btn-solid:hover{background:var(--accent);border-color:var(--accent)}
.btn-acc{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-acc:hover{background:var(--ink);border-color:var(--ink)}
.btn-w{border-color:#fff;color:#fff}
.btn-w:hover{background:#fff;color:var(--ink)}

/* ---------- ticker ---------- */
.ticker{overflow:hidden;border-block:1px solid var(--line);padding:18px 0;background:var(--bg)}
.ticker-track{display:flex;gap:64px;white-space:nowrap;animation:tick 30s linear infinite;font-family:'Space Grotesk',sans-serif;font-size:.86rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.ticker-track b{color:var(--accent);font-weight:600}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- page hero (interior pages) ---------- */
.page-hero{padding:190px 0 90px}
.page-hero .crumb{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.page-hero .crumb b{color:var(--accent);font-weight:600}

/* ---------- footer ---------- */
footer{background:var(--dark);color:#CFCCC2;padding:90px 0 40px;margin-top:0}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding-bottom:60px;border-bottom:1px solid #2A2925}
.f-grid h4{color:#fff;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:20px}
.f-grid p,.f-grid li{font-size:.9rem;font-weight:300;color:#8F8C82}
.f-grid ul{list-style:none;display:grid;gap:10px}
.f-grid ul a:hover{color:var(--accent)}
.f-big{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);color:#fff;line-height:1.2;margin-bottom:18px;letter-spacing:-.01em}
.f-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:32px;font-size:.78rem;color:#8F8C82}
.f-bot b{color:var(--accent)}
@media(max-width:880px){.f-grid{grid-template-columns:1fr 1fr}}

/* ---------- cards & grids ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:920px){.grid-2,.grid-3{grid-template-columns:1fr}}
.tile{border:1px solid var(--line);padding:42px 36px;background:#fff;transition:.3s}
.tile:hover{border-color:var(--ink);transform:translateY(-6px)}
.tile .no{font-family:'Space Grotesk',sans-serif;font-size:.8rem;letter-spacing:.2em;color:var(--accent);font-weight:600;margin-bottom:30px;display:block}
.tile h3{font-size:1.2rem;margin-bottom:12px}
.tile p{color:var(--muted);font-size:.92rem;font-weight:300}

/* ---------- media frames ---------- */
.media{overflow:hidden;position:relative}
.media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s ease}
.media:hover img{transform:scale(1.045)}
.media .tag{position:absolute;left:18px;bottom:18px;background:rgba(18,18,16,.78);backdrop-filter:blur(8px);color:#fff;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:9px 16px}

/* ---------- dark band ---------- */
.band{background:var(--dark);color:#EDEAE0}
.band .sub{color:#9B988E}
.band .eyebrow{color:var(--accent)}
.band h2,.band h3{color:#fff}

/* ---------- stats row ---------- */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);background:#fff}
.stats-row>div{padding:42px 30px;border-right:1px solid var(--line)}
.stats-row>div:last-child{border-right:0}
.stats-row .v{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.2rem,3.6vw,3.4rem);font-weight:600;letter-spacing:-.03em}
.stats-row .v em{font-style:normal;color:var(--accent)}
.stats-row .k{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:8px}
@media(max-width:880px){.stats-row{grid-template-columns:1fr 1fr}.stats-row>div:nth-child(2){border-right:0}}

/* ---------- list rows (architecture page etc) ---------- */
.row-list{border-top:1px solid var(--line)}
.row-item{display:grid;grid-template-columns:90px 1.2fr 2fr auto;gap:30px;align-items:center;padding:34px 6px;border-bottom:1px solid var(--line);transition:.25s}
.row-item:hover{background:#fff;padding-left:18px}
.row-item .ri-no{font-family:'Space Grotesk',sans-serif;color:var(--muted);font-size:.85rem;letter-spacing:.1em}
.row-item h3{font-size:1.15rem}
.row-item p{color:var(--muted);font-size:.9rem;font-weight:300}
.row-item .ri-val{font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--accent);white-space:nowrap}
@media(max-width:880px){.row-item{grid-template-columns:1fr;gap:8px}}

/* ---------- forms ---------- */
input,textarea,select{font-family:'Inter',sans-serif;width:100%;padding:16px 18px;border:1px solid var(--line);background:#fff;font-size:.95rem;color:var(--ink);outline:none;transition:border .2s}
input:focus,textarea:focus{border-color:var(--accent)}
label{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;background:rgba(14,14,12,.93);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:200;padding:4vw}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;object-fit:contain;background:#fff}
.lightbox .x{position:absolute;top:24px;right:32px;color:#fff;font-size:2rem;cursor:pointer;opacity:.8}
