/* ============ MELIORA — Brand Guide stylesheet ============ */
:root{
  --paper:#F4F1EA;
  --paper-2:#ECE7DB;
  --ink:#16140F;
  --ink-2:#1C1A14;
  --muted:#6E685B;
  --line:rgba(22,20,15,.12);

  --vermilion:#FF4D2E;
  --cobalt:#2440E8;
  --marigold:#FFB323;
  --chartreuse:#C2EA4B;
  --pink:#FF6FB5;
  --teal:#00B39A;

  --maxw:1240px;
  --gut:clamp(20px,4vw,64px);

  --display:"Bricolage Grotesque",ui-sans-serif,system-ui,sans-serif;
  --text:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;
  --serif:"Instrument Serif",Georgia,serif;
  --mono:"Space Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--text);font-size:17px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--vermilion);color:#fff;}
a{color:inherit;}
img{max-width:100%;display:block;}

/* ---------- layout primitives ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
.section{padding-block:clamp(64px,10vw,140px);border-top:1px solid var(--line);}
.section--flush{border-top:none;}

.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);display:flex;align-items:center;gap:12px;margin:0 0 28px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.5;}
.eyebrow .num{color:var(--vermilion);}

h2.h{font-family:var(--display);font-weight:700;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(34px,6vw,68px);margin:0 0 .5em;text-wrap:balance;}
.lead{font-size:clamp(19px,2.4vw,27px);line-height:1.4;max-width:58ch;color:var(--ink);
  font-weight:400;text-wrap:pretty;}
.muted{color:var(--muted);}

/* ---------- monogram base ---------- */
.logo{display:block;}
.logo use{stroke-linejoin:miter;}

/* ============ TOP BAR ============ */
.topbar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.topbar .inner{display:flex;align-items:center;justify-content:space-between;height:62px;}
.brandlock{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;
  font-size:19px;letter-spacing:-.02em;text-decoration:none;}
.brandlock .logo{width:26px;height:26px;color:var(--ink);}
.navlinks{display:flex;gap:26px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;}
.navlinks a{text-decoration:none;color:var(--muted);transition:color .2s;}
.navlinks a:hover{color:var(--ink);}
@media(max-width:720px){.navlinks{display:none;}}

/* ============ HERO ============ */
.hero{padding-block:clamp(48px,8vw,96px) clamp(56px,9vw,120px);position:relative;overflow:hidden;}
.hero .meta-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  padding-bottom:clamp(40px,7vw,90px);}
.hero .stage{display:flex;align-items:center;gap:clamp(20px,4vw,56px);flex-wrap:wrap;}
.hero .bigM{width:clamp(150px,26vw,320px);height:clamp(150px,26vw,320px);flex:0 0 auto;}
.hero .wordcol{flex:1 1 360px;min-width:280px;}
.wordmark{font-family:var(--display);font-weight:700;letter-spacing:-.035em;line-height:.86;
  font-size:clamp(64px,15vw,180px);margin:0;}
.hero .tag{font-size:clamp(18px,2.3vw,25px);max-width:30ch;margin:.7em 0 0;color:var(--ink);text-wrap:pretty;}
.hero .ruler{display:flex;flex-wrap:wrap;gap:8px 28px;margin-top:clamp(40px,7vw,84px);
  padding-top:24px;border-top:1px solid var(--ink);font-family:var(--mono);font-size:12.5px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.hero .ruler b{color:var(--ink);font-weight:700;}

/* colorway chips under hero M */
.cw-row{display:flex;gap:10px;margin-top:22px;}
.cw{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);cursor:pointer;
  display:grid;place-items:center;padding:0;background:var(--paper);transition:transform .15s;}
.cw:hover{transform:translateY(-2px);}
.cw[aria-pressed="true"]{outline:2px solid var(--ink);outline-offset:2px;}
.cw svg{width:18px;height:18px;}

/* ============ generic two-col ============ */
.split{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(28px,5vw,72px);
  align-items:start;}
@media(max-width:860px){.split{grid-template-columns:1fr;}}

/* ============ LOGO SYSTEM ============ */
.logo-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin-top:48px;}
.card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;
  display:flex;flex-direction:column;}
.card .cap{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-top:auto;padding-top:22px;}
.card .cap b{color:var(--ink);font-weight:700;}
.card .stagebox{flex:1;display:grid;place-items:center;min-height:190px;}
.span-7{grid-column:span 7;}.span-5{grid-column:span 5;}
.span-6{grid-column:span 6;}.span-4{grid-column:span 4;}.span-3{grid-column:span 3;}.span-2{grid-column:span 2;}
.span-8{grid-column:span 8;}.span-12{grid-column:span 12;}
@media(max-width:860px){
  .logo-grid [class*=span-]{grid-column:span 12;}
  .logo-grid .half{grid-column:span 6;}
}
.card.dark{background:var(--ink);border-color:transparent;}
.card.dark .cap{color:rgba(244,241,234,.55);}
.card.dark .cap b{color:var(--paper);}
.card.tint-v{background:var(--vermilion);border-color:transparent;}
.card.tint-c{background:var(--cobalt);border-color:transparent;}
.card.tint-v .cap,.card.tint-c .cap{color:rgba(255,255,255,.7);}
.card.tint-v .cap b,.card.tint-c .cap b{color:#fff;}

.lockup{display:flex;align-items:center;gap:18px;font-family:var(--display);font-weight:700;
  font-size:clamp(38px,7vw,76px);letter-spacing:-.035em;line-height:1;}
.lockup .logo{width:.92em;height:.92em;flex:0 0 auto;}

/* clear space diagram */
.clearspace{position:relative;width:230px;height:230px;display:grid;place-items:center;}
.clearspace .frame{position:absolute;inset:0;border:1px dashed var(--vermilion);border-radius:6px;}
.clearspace .pad{position:absolute;inset:46px;border:1px dashed var(--cobalt);opacity:.5;}
.clearspace .logo{width:110px;height:110px;color:var(--ink);position:relative;}
.guide-tag{position:absolute;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--vermilion);}

/* don'ts */
.donts{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px;}
@media(max-width:760px){.donts{grid-template-columns:repeat(2,1fr);}}
.dont{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;
  display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center;}
.dont .box{height:96px;display:grid;place-items:center;width:100%;}
.dont .x{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.dont .x::before{content:"✕  ";color:var(--vermilion);font-weight:700;}

/* ============ COLOR ============ */
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px;}
@media(max-width:880px){.swatches{grid-template-columns:repeat(2,1fr);}}
.sw{border-radius:18px;border:1px solid var(--line);overflow:hidden;cursor:pointer;
  background:#fff;text-align:left;font:inherit;padding:0;display:flex;flex-direction:column;
  transition:transform .15s,box-shadow .2s;}
.sw:hover{transform:translateY(-3px);box-shadow:0 12px 30px -18px rgba(0,0,0,.4);}
.sw .chip{height:128px;}
.sw .meta{padding:16px 18px 20px;}
.sw .nm{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;}
.sw .hex{font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:3px;
  display:flex;justify-content:space-between;align-items:center;}
.sw .role{font-size:13.5px;color:var(--muted);margin-top:9px;line-height:1.35;}
.sw .copy{font-family:var(--mono);font-size:10px;letter-spacing:.1em;opacity:0;transition:opacity .2s;}
.sw:hover .copy{opacity:.8;}

.mixstrip{display:flex;height:84px;margin-top:24px;border-radius:14px;overflow:hidden;border:1px solid var(--line);}
.mixstrip span{flex:1;}

/* ============ TYPE ============ */
.type-spec{margin-top:48px;display:flex;flex-direction:column;gap:0;}
.tline{border-top:1px solid var(--line);padding:30px 0;display:grid;
  grid-template-columns:170px 1fr;gap:24px;align-items:baseline;}
.tline:last-child{border-bottom:1px solid var(--line);}
.tline .label{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.tline .label b{display:block;color:var(--ink);font-size:13px;letter-spacing:0;text-transform:none;
  font-family:var(--text);font-weight:600;margin-top:6px;}
.tline .sample{min-width:0;}
@media(max-width:680px){.tline{grid-template-columns:1fr;}}

.scale{display:flex;flex-direction:column;gap:6px;margin-top:46px;border-top:1px solid var(--line);padding-top:30px;}
.scale .row{display:flex;align-items:baseline;gap:20px;}
.scale .row .sz{font-family:var(--mono);font-size:12px;color:var(--muted);width:74px;flex:0 0 auto;}
.scale .row .ex{font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ============ APPLICATIONS ============ */
.apps{display:grid;grid-template-columns:repeat(12,1fr);gap:20px;margin-top:48px;align-items:start;}
.app{border-radius:22px;overflow:hidden;position:relative;border:1px solid var(--line);background:#fff;}
.app .label{position:absolute;left:16px;bottom:14px;font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:color-mix(in srgb,var(--paper) 80%,transparent);
  padding:5px 10px;border-radius:99px;backdrop-filter:blur(4px);z-index:3;}
.app.dark .label{color:rgba(244,241,234,.7);background:rgba(0,0,0,.3);}

/* business card */
.bizcard{aspect-ratio:1.62/1;padding:30px;display:flex;flex-direction:column;justify-content:space-between;}
.bizcard.front{background:var(--ink);color:var(--paper);}
.bizcard.back{background:var(--paper-2);color:var(--ink);}
.bizcard .top{display:flex;justify-content:space-between;align-items:flex-start;}
.bizcard .logo{width:46px;height:46px;}
.bizcard .nm{font-family:var(--display);font-weight:700;font-size:clamp(20px,3vw,30px);letter-spacing:-.02em;line-height:1.05;}
.bizcard .sub{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.7;margin-top:4px;}
.bizcard .det{font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;line-height:1.7;opacity:.85;}

/* avatar + cover */
.avatar{aspect-ratio:1/1;display:grid;place-items:center;background:var(--ink);}
.avatar .squircle{width:64%;height:64%;border-radius:30%;display:grid;place-items:center;
  background:var(--paper);}
.avatar .squircle svg{width:62%;height:62%;}
.cover{aspect-ratio:3/1;background:var(--cobalt);position:relative;display:flex;align-items:center;
  padding-inline:clamp(24px,4vw,56px);overflow:hidden;}
.cover .ttl{font-family:var(--display);font-weight:700;color:#fff;font-size:clamp(28px,5vw,54px);
  letter-spacing:-.03em;line-height:.95;z-index:2;}
.cover .ttl small{display:block;font-family:var(--mono);font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;opacity:.8;font-weight:400;margin-top:10px;}
.cover .ghostM{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:62%;opacity:.9;}

/* poster (art expression) */
.poster{aspect-ratio:3/4;background:var(--paper-2);position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;padding:30px;}
.poster .pmeta{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink);z-index:2;display:flex;justify-content:space-between;}
.poster .ptitle{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,52px);
  line-height:.92;letter-spacing:-.03em;z-index:2;}
.poster .art{flex:1;display:grid;place-items:center;padding-block:14px;}
.poster .art svg{width:66%;}

/* website mock */
.web{grid-column:span 12;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#fff;}
.web .chrome{height:42px;background:var(--paper-2);display:flex;align-items:center;gap:8px;padding-inline:16px;
  border-bottom:1px solid var(--line);}
.web .chrome i{width:11px;height:11px;border-radius:50%;background:var(--line);display:block;}
.web .chrome .url{margin-left:14px;font-family:var(--mono);font-size:12px;color:var(--muted);
  background:var(--paper);padding:5px 14px;border-radius:99px;}
.web .viewport{padding:clamp(34px,5vw,64px);display:grid;grid-template-columns:1.15fr .85fr;
  gap:40px;align-items:center;min-height:340px;}
@media(max-width:760px){.web .viewport{grid-template-columns:1fr;}}
.web .h1{font-family:var(--display);font-weight:700;font-size:clamp(34px,5.4vw,62px);
  letter-spacing:-.035em;line-height:.96;margin:0;}
.web .h1 em{font-style:normal;color:var(--vermilion);}
.web .sub{color:var(--muted);font-size:17px;margin-top:18px;max-width:42ch;}
.web .cta{display:inline-flex;gap:12px;margin-top:26px;align-items:center;}
.web .btn{font-family:var(--text);font-weight:600;font-size:15px;padding:13px 24px;border-radius:99px;
  background:var(--ink);color:var(--paper);text-decoration:none;}
.web .btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}
.web .heroart{aspect-ratio:1/1;border-radius:20px;background:var(--ink);display:grid;place-items:center;}
.web .heroart svg{width:58%;}

.app.span-3{grid-column:span 3;}
.app.span-4{grid-column:span 4;}
.app.span-5{grid-column:span 5;}
.app.span-6{grid-column:span 6;}
.app.span-7{grid-column:span 7;}
.app.span-8{grid-column:span 8;}
.app.span-9{grid-column:span 9;}
@media(max-width:860px){
  .apps .app{grid-column:span 6;}
  .apps .app.full,.apps .web{grid-column:span 12;}
}
@media(max-width:560px){.apps .app{grid-column:span 12;}}

/* ============ VOICE ============ */
.voice{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px;}
@media(max-width:760px){.voice{grid-template-columns:1fr;}}
.vcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;}
.vcard h4{font-family:var(--display);font-weight:700;font-size:21px;margin:0 0 8px;letter-spacing:-.01em;}
.vcard p{margin:0;color:var(--muted);font-size:15.5px;line-height:1.5;}
.vcard .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--vermilion);margin-bottom:14px;}

.tagbig{font-family:var(--display);font-weight:700;font-size:clamp(40px,9vw,128px);
  letter-spacing:-.04em;line-height:.9;margin:0;text-wrap:balance;}
.tagbig .grad{background:linear-gradient(120deg,var(--vermilion),var(--pink) 38%,var(--cobalt) 72%,var(--teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;}

/* ============ FOOTER ============ */
.foot{border-top:1px solid var(--ink);padding-block:48px 60px;}
.foot .row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;}
.foot .big{font-family:var(--display);font-weight:700;font-size:clamp(30px,6vw,64px);letter-spacing:-.03em;line-height:1;}
.foot .meta{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:right;line-height:2;}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;
  padding:12px 20px;border-radius:99px;opacity:0;pointer-events:none;transition:.25s;z-index:99;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}
