/* ============================================================
   10yx — site stylesheet
   Composes the 10yx design-system tokens. Deep petrol-ink ground,
   warm serif voice, mono signal. Shared across every page.
   ============================================================ */

@import url('ds/styles.css');

html, body { background: var(--ink); }
body { overflow-x: hidden; }
a { color: inherit; }

::selection { background: var(--select-bg); color: var(--on-dark); }

/* ---------- skip link ---------- */
.skip { position:absolute; left:-9999px; top:0; z-index:200;
  font-family:var(--font-mono); font-size:12px; padding:10px 16px;
  background:var(--sage); color:var(--ink); }
.skip:focus { left:16px; top:12px; }

/* ============================================================
   HEADER
   ============================================================ */
.hdr { position:fixed; top:0; left:0; right:0; z-index:var(--z-header);
  display:flex; justify-content:space-between; align-items:center;
  padding:20px clamp(20px,4vw,48px);
  background:var(--scrim-header); backdrop-filter:var(--blur-header); }
.hdr .brand { display:flex; align-items:center; gap:11px; }
.hdr .brand img { height:24px; width:auto; }
.hdr .brand b { font-family:var(--font-mono); font-weight:700; font-size:17px;
  letter-spacing:-.02em; color:var(--on-dark); }
.nav { display:flex; gap:26px; }
.nav a { font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--on-dark-faint);
  transition:color var(--dur-base) var(--ease-out); }
.nav a:hover, .nav a.active { color:var(--sage); }

/* ============================================================
   BUTTONS  (mirror DS Button)
   ============================================================ */
.btn { font-family:var(--font-mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; padding:14px 28px; border-radius:var(--r-2);
  border:1px solid transparent; cursor:pointer; text-decoration:none;
  display:inline-flex; align-items:center; gap:8px;
  transition:all var(--dur-base) var(--ease-out); }
.btn-solid { background:var(--sage); color:var(--ink); border-color:var(--sage); }
.btn-solid:hover { background:#b3c4b9; transform:translateY(-2px); }
.btn-out { color:var(--on-dark); border-color:var(--ink-600); }
.btn-out:hover { border-color:var(--sage); color:var(--sage); }

/* badge / status pill */
.badge { display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-mono); font-size:9px; letter-spacing:.18em;
  text-transform:uppercase; padding:4px 11px; border-radius:var(--r-pill);
  border:1px solid var(--sage); color:var(--sage); }
.badge .dot { width:6px; height:6px; border-radius:50%; background:currentColor;
  animation:pulse-soft 2.4s ease-in-out infinite; }
.badge.muted { color:var(--on-dark-faint); border-color:var(--ink-600); }
.badge.muted .dot { animation:none; background:var(--on-dark-faint); }

/* ============================================================
   HERO  (homepage)
   ============================================================ */
.hero { position:relative; min-height:100vh; display:flex; align-items:center;
  justify-content:center; overflow:hidden; }
#scene { position:absolute; inset:0; pointer-events:none; }
.ghost { position:absolute; color:transparent; -webkit-text-stroke:1px var(--on-dark-ghost);
  font-family:var(--font-serif); font-weight:300; user-select:none;
  pointer-events:none; z-index:1; }
.hero-c { position:relative; z-index:3; text-align:center; padding:24px; max-width:880px; }
.hero-c .eb { margin-bottom:26px; }
.hero-c h1 { font-size:var(--t-display); font-weight:var(--w-thin); line-height:1;
  letter-spacing:-.02em; color:var(--on-dark); margin:0 0 22px; }
.hero-c h1 em { font-weight:var(--w-light); }
.hero-c .sub { font-family:var(--font-serif); font-weight:300; font-size:var(--t-lead);
  line-height:1.6; color:var(--on-dark-muted); max-width:42ch; margin:0 auto 18px; }
.eq { font-family:var(--font-mono); font-size:12px; letter-spacing:.18em;
  color:var(--on-dark-faint); margin-bottom:34px; }
.cta { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.scroll { position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--on-dark-faint); text-align:center; }
.scroll span { display:block; margin-top:8px; animation:bob-down 2.2s ease-in-out infinite; }

/* ============================================================
   SECTIONS  (homepage)
   ============================================================ */
.sec { max-width:var(--measure-wide); margin:0 auto;
  padding:var(--pad-section) var(--pad-gutter); }
.sec h2 { font-size:var(--t-h2); font-weight:var(--w-light); color:var(--on-dark);
  max-width:20ch; margin:18px 0 0; }
.lead { font-family:var(--font-serif); font-weight:300; font-size:var(--t-lead);
  line-height:1.7; color:var(--on-dark-muted); max-width:48ch; margin:24px 0 0; }

.grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1px;
  background:var(--line-on-dark); border:1px solid var(--line-on-dark); margin-top:64px; }
.cell { background:var(--ink); padding:38px 34px;
  transition:background var(--dur-base) var(--ease-out); }
.cell:hover { background:var(--ink-700); }
.cell .n { font-family:var(--font-mono); font-size:13px; letter-spacing:.2em;
  color:var(--sage); margin-bottom:18px; }
.cell h3 { font-size:var(--t-h3); font-weight:var(--w-regular); color:var(--on-dark); margin:0 0 12px; }
.cell p { font-family:var(--font-serif); font-size:15px; line-height:1.7;
  color:var(--on-dark-muted); margin:0; }

/* quote band */
.quote { border-top:1px solid var(--line-on-dark); border-bottom:1px solid var(--line-on-dark);
  text-align:center; padding:var(--pad-section) var(--pad-gutter); }
.quote blockquote { font-family:var(--font-serif); font-style:italic; font-weight:200;
  font-size:clamp(1.5rem,3.4vw,2.6rem); line-height:1.4; color:var(--on-dark);
  max-width:24ch; margin:0 auto 18px; }
.quote .attr { font-family:var(--font-mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--on-dark-faint); }

/* ============================================================
   PRODUCT FEATURE  (paper band)
   ============================================================ */
.band-paper { background:var(--paper-1); border-top:1px solid var(--line-on-dark);
  border-bottom:1px solid var(--line-on-dark); }
.band-paper .sec h2 { color:var(--on-light); }
.band-paper .lead { color:var(--on-light-muted); }
.band-paper .t-eyebrow { color:var(--sage-dim); }
.band-paper .btn-out { color:var(--on-light); border-color:var(--paper-line); }
.band-paper .btn-out:hover { border-color:var(--sage-dim); color:var(--sage-dim); }
.prod { display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.appwin { border-radius:6px; overflow:hidden; border:1px solid var(--paper-line); background:var(--paper);
  box-shadow:0 30px 64px rgba(0,26,32,.20),0 4px 12px rgba(0,26,32,.10); }
.appbar { display:flex; align-items:center; gap:7px; padding:11px 15px;
  border-bottom:1px solid var(--paper-line); background:var(--paper-2); }
.appbar .dot { width:10px; height:10px; border-radius:50%; background:#cfccc4; }
.appbar .wt { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em;
  color:var(--on-light-faint); margin-left:10px; text-transform:uppercase; }
.appwin .media { aspect-ratio:4/3; background:var(--paper); display:flex;
  align-items:center; justify-content:center; }

/* DayDesigner dial mock */
.dddial { position:relative; height:86%; aspect-ratio:1; }
.ddblocks { position:absolute; inset:6%; border-radius:50%;
  background:conic-gradient(#b5862f 0deg 75deg, var(--paper-1) 75deg 90deg, #1b1b18 90deg 98deg,
    var(--paper-1) 98deg 120deg, #21456b 120deg 165deg, #4f79a8 165deg 180deg, #c9b489 180deg 210deg,
    #3f5e3a 210deg 225deg, var(--paper-1) 225deg 240deg, #b1442f 240deg 255deg, #3f6896 255deg 278deg,
    var(--paper-1) 278deg 300deg, #b8b58a 300deg 330deg, var(--paper-1) 330deg 360deg);
  -webkit-mask:radial-gradient(circle, transparent 60%, #000 61%); mask:radial-gradient(circle, transparent 60%, #000 61%); }
.ddtick { position:absolute; inset:6%; border-radius:50%;
  background:repeating-conic-gradient(#00252d 0deg .3deg, transparent .3deg 15deg);
  -webkit-mask:radial-gradient(circle, transparent 57%, #000 58% 61%, transparent 62%);
  mask:radial-gradient(circle, transparent 57%, #000 58% 61%, transparent 62%); opacity:.30; }
.ddhours .hr { position:absolute; transform:translate(-50%,-50%); font-family:var(--font-mono);
  font-size:11px; letter-spacing:.05em; color:var(--on-light-muted); }
.ddclock { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:4px; text-align:center; }
.ddclock .day { font-family:var(--font-mono); font-size:9px; letter-spacing:.24em; color:var(--on-light-faint); }
.ddclock .time { font-family:var(--font-serif); font-weight:300; font-size:clamp(30px,4.5vw,46px); color:var(--on-light); line-height:1; }
.ddclock .act { font-family:var(--font-serif); font-style:italic; font-size:14px; color:var(--on-light-muted); }

/* ============================================================
   INNER PAGES  (about / products / legal / news / contact)
   ============================================================ */
.page-head { max-width:var(--measure-wide); margin:0 auto;
  padding:calc(var(--pad-section) + 40px) var(--pad-gutter) 0; }
.page-head .eb { margin-bottom:22px; }
.page-head h1 { font-family:var(--font-serif); font-size:var(--t-h1); font-weight:var(--w-thin);
  letter-spacing:-.02em; color:var(--on-dark); margin:0; max-width:18ch; }
.page-head .lead { margin-top:26px; max-width:54ch; }
.page-head .meta { font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--on-dark-faint); margin-top:26px; }

.page-rule { max-width:var(--measure-wide); margin:64px auto 0; padding:0 var(--pad-gutter); }
.page-rule hr { border-top:1px solid var(--line-on-dark); }

/* prose / reading column */
.prose { max-width:var(--measure-wide); margin:0 auto;
  padding:64px var(--pad-gutter) var(--pad-section);
  display:grid; grid-template-columns:1fr; }
.prose-col { max-width:66ch; }
.prose-col.wide { max-width:none; }
.prose h2 { font-family:var(--font-serif); font-size:var(--t-h3); font-weight:var(--w-light);
  color:var(--on-dark); letter-spacing:-.01em; margin:56px 0 6px; padding-top:26px;
  border-top:1px solid var(--line-on-dark); }
.prose h2:first-child { margin-top:0; padding-top:0; border-top:0; }
.prose h3 { font-family:var(--font-mono); font-size:11px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--sage); margin:30px 0 10px; }
.prose p { font-family:var(--font-serif); font-size:var(--t-body); line-height:1.85;
  color:var(--on-dark-muted); margin:0 0 18px; }
.prose p strong, .prose li strong { color:var(--on-dark); font-weight:var(--w-semibold); }
.prose a { color:var(--sage); border-bottom:1px solid rgba(159,179,166,.32);
  transition:border-color var(--dur-base) var(--ease-out); }
.prose a:hover { border-color:var(--sage); }
.prose ul, .prose ol { list-style:none; margin:0 0 22px; padding:0; }
.prose li { font-family:var(--font-serif); font-size:var(--t-body); line-height:1.7;
  color:var(--on-dark-muted); padding-left:26px; position:relative; margin-bottom:11px; }
.prose ul li::before { content:'—'; position:absolute; left:0; color:var(--sage);
  font-family:var(--font-mono); }
.prose ol { counter-reset:li; }
.prose ol li { counter-increment:li; }
.prose ol li::before { content:counter(li,decimal-leading-zero); position:absolute; left:0;
  color:var(--sage); font-family:var(--font-mono); font-size:12px; top:3px; }

/* definition grid (about company details) */
.spec { display:grid; grid-template-columns:auto 1fr; gap:10px 28px; margin:8px 0 22px;
  border-top:1px solid var(--line-on-dark); padding-top:22px; }
.spec dt { font-family:var(--font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--sage); padding-top:3px; }
.spec dd { font-family:var(--font-serif); color:var(--on-dark-muted); margin:0; }

/* callout box */
.callout { border:1px solid var(--line-on-dark); border-left:2px solid var(--sage);
  background:var(--ink-700); padding:26px 30px; margin:24px 0 26px; }
.callout ul { margin-bottom:0; }

/* data table */
.tbl { width:100%; border-collapse:collapse; margin:20px 0 26px;
  font-family:var(--font-serif); font-size:var(--t-small); }
.tbl th, .tbl td { text-align:left; padding:13px 16px; border:1px solid var(--line-on-dark);
  color:var(--on-dark-muted); }
.tbl th { font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--sage); background:var(--ink-700); font-weight:400; }

/* product cards (products page) */
.pcard { border:1px solid var(--line-on-dark); background:var(--ink-700);
  padding:clamp(30px,4vw,52px); margin-bottom:28px; }
.pcard > .head { display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:22px; }
.pcard h2 { font-family:var(--font-serif); font-size:var(--t-h2); font-weight:var(--w-light);
  color:var(--on-dark); margin:0; border:0; padding:0; }

/* news list */
.news-item { border-top:1px solid var(--line-on-dark); padding:42px 0;
  display:grid; grid-template-columns:160px 1fr; gap:clamp(20px,4vw,56px); align-items:start; }
.news-item:last-child { border-bottom:1px solid var(--line-on-dark); }
.news-item time { font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--on-dark-faint); padding-top:8px; }
.news-item h2 { font-family:var(--font-serif); font-size:var(--t-h3); font-weight:var(--w-regular);
  color:var(--on-dark); margin:0 0 12px; border:0; padding:0; }
.news-item p { font-family:var(--font-serif); font-size:var(--t-body); line-height:1.8;
  color:var(--on-dark-muted); margin:0; }

/* contact cards */
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1px; background:var(--line-on-dark); border:1px solid var(--line-on-dark); margin-top:8px; }
.contact-cell { background:var(--ink); padding:40px 36px; }
.contact-cell .k { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--sage); margin-bottom:16px; }
.contact-cell a { font-family:var(--font-serif); font-size:var(--t-lead); color:var(--on-dark);
  border-bottom:1px solid rgba(159,179,166,.3); }
.contact-cell a:hover { border-color:var(--sage); color:var(--sage); }
.contact-cell address { font-style:normal; font-family:var(--font-serif); line-height:1.8;
  color:var(--on-dark-muted); }

/* simple CTA strip */
.cta-strip { max-width:var(--measure-wide); margin:0 auto;
  padding:0 var(--pad-gutter) var(--pad-section); text-align:center; }
.cta-strip .inner { border-top:1px solid var(--line-on-dark); padding-top:var(--pad-section);
  display:flex; flex-direction:column; align-items:center; gap:24px; }
.cta-strip p { font-family:var(--font-serif); font-weight:300; font-size:var(--t-lead);
  color:var(--on-dark-muted); max-width:40ch; }

/* 404 */
.notfound { min-height:100vh; display:flex; flex-direction:column; align-items:center;
  justify-content:center; text-align:center; padding:120px 24px 80px; gap:22px; }
.notfound .code { font-family:var(--font-serif); font-weight:var(--w-thin);
  font-size:clamp(5rem,18vw,12rem); line-height:1; color:var(--on-dark); }
.notfound p { font-family:var(--font-serif); font-weight:300; font-size:var(--t-lead);
  color:var(--on-dark-muted); max-width:36ch; }

/* ============================================================
   FOOTER
   ============================================================ */
.ft { border-top:1px solid var(--line-on-dark); padding:64px var(--pad-gutter) 48px;
  max-width:var(--measure-wide); margin:0 auto; }
.ft-row { display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; align-items:flex-end; }
.ft-brand { display:flex; align-items:center; gap:12px; }
.ft-brand img { height:30px; }
.ft-brand .nm { font-family:var(--font-mono); font-weight:700; color:var(--on-dark); font-size:15px; }
.ft-brand .tag { font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; color:var(--on-dark-faint); }
.ft-links { display:flex; gap:22px; flex-wrap:wrap; font-family:var(--font-mono); font-size:11px;
  letter-spacing:.14em; text-transform:uppercase; }
.ft-links a { color:var(--on-dark-faint); transition:color var(--dur-base) var(--ease-out); }
.ft-links a:hover { color:var(--sage); }
.ft-base { max-width:var(--measure-wide); margin:0 auto; padding:0 var(--pad-gutter) 56px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; color:var(--on-dark-faint); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:760px) {
  .prod { grid-template-columns:1fr; }
  .nav { display:none; }
  .news-item { grid-template-columns:1fr; gap:10px; }
  .news-item time { padding-top:0; }
  .ft-row { flex-direction:column; align-items:flex-start; }
}
