/* ============================================================
   THE DRY SHIELD — Waterproofing Specialists
   Built on the Fallen Luxury monochrome-editorial system.
   Adapted as a premium "architectural waterproofing" brand.
   ============================================================ */

:root {
  --ds-head-h: 78px;
  --sec-pad: clamp(60px, 8vw, 110px);
  --display-weight: 500;
  /* Accent hooks — overridden live by the Tweaks panel.
     Default = on-brand graphite (no colour). */
  --brand: var(--gold-700);
  --brand-soft: var(--gold-200);
  --brand-wash: var(--gold-100);
}

body { background: var(--ivory); color: var(--ink-700); overflow-x: hidden; }
.ds-wrap { max-width: var(--container); margin: 0 auto; padding-inline: var(--gutter); }
a { color: inherit; }
img { display: block; }

/* ---------- Announcement ---------- */
.ds-announce {
  background: var(--ink-900); color: var(--ivory);
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  display: flex; align-items: center; justify-content: center; gap: 30px; height: 40px; text-align: center;
}
.ds-announce span { display: inline-flex; align-items: center; gap: 9px; opacity: 0.92; }
.ds-announce .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--ink-400); }
@media (max-width: 760px){ .ds-announce span:nth-child(n+3){ display:none; } .ds-announce{ gap:22px; } }

/* ---------- Header ---------- */
.ds-header {
  position: sticky; top: 0; z-index: 50; height: var(--ds-head-h);
  display: flex; align-items: center;
  background: color-mix(in srgb, var(--paper) 86%, transparent);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: 1px solid transparent; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ds-header.scrolled { border-color: var(--line); box-shadow: 0 1px 0 rgba(27,24,19,0.02); }
.ds-header .ds-wrap { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; width: 100%; }
.ds-nav { display: flex; gap: 30px; font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-700); }
.ds-nav a { position: relative; padding-bottom: 3px; transition: color var(--dur) var(--ease); }
.ds-nav a::after { content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background: var(--ink-900); transition: right var(--dur) var(--ease); }
.ds-nav a:hover { color: var(--ink-900); }
.ds-nav a:hover::after { right: 0; }

.ds-logo { display:flex; flex-direction:column; align-items:center; text-align:center; gap:2px; }
.ds-logo .mark { font-family: var(--font-display); font-weight: 500; font-size: 23px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-900); white-space: nowrap; line-height:1; }
.ds-logo .sub { font-family: var(--font-sans); font-size: 8.5px; letter-spacing: 0.42em; text-transform: uppercase; color: var(--ink-500); }

.ds-utils { display: flex; align-items: center; justify-content: flex-end; gap: 16px; }
.ds-phone { display:inline-flex; align-items:center; gap:9px; white-space:nowrap; font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.04em; color: var(--ink-800); }
.ds-phone svg { width: 17px; height: 17px; stroke-width:1.5; color: var(--ink-900); }
.ds-phone .pn { font-weight: 500; }
.ds-pill { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500; color: var(--ivory); background: var(--ink-900); border: 1px solid var(--ink-900); border-radius: 2px; padding: 11px 18px; transition: background var(--dur) var(--ease), color var(--dur) var(--ease); white-space:nowrap; }
.ds-pill:hover { background: var(--ink-700); }
@media (max-width: 1040px){ .ds-nav { gap:22px; } }
@media (max-width: 940px){ .ds-nav, .ds-phone .pn { display:none; } .ds-header .ds-wrap{ grid-template-columns: 1fr auto; } .ds-logo{ align-items:flex-start; } }

/* ---------- Buttons ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:11px; font-family: var(--font-sans); font-size: 12px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; height: 56px; padding: 0 34px; border: 1px solid transparent; border-radius: 2px; cursor:pointer; transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur-fast) var(--ease); }
.btn:active { transform: translateY(1px); }
.btn svg { width: 16px; height: 16px; stroke-width:1.5; }
.btn-ink { background: var(--ink-900); color: var(--ivory); }
.btn-ink:hover { background: var(--ink-700); box-shadow: var(--shadow-md); }
.btn-outline { background: transparent; color: var(--ink-900); border-color: var(--ink-900); }
.btn-outline:hover { background: var(--ink-900); color: var(--ivory); }
.btn-full { width: 100%; }

.eyebrow { display:inline-flex; align-items:center; gap:13px; font-family: var(--font-sans); font-size: 12px; font-weight: 500; letter-spacing: 0.24em; text-transform: uppercase; color: var(--brand); }
.eyebrow::before { content:""; width: 30px; height:1px; background: currentColor; opacity:.6; }
.eyebrow.center::before { display:none; }

/* ---------- Hero ---------- */
.hero { padding: clamp(46px, 6.5vw, 92px) 0 clamp(38px, 5vw, 64px); }
.hero .ds-wrap { display:grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 5vw, 76px); align-items: center; }
.hero-h1 { font-family: var(--font-display); font-weight: 500; color: var(--ink-900); font-size: clamp(42px, 5.4vw, 78px); line-height: 1.02; letter-spacing: -0.015em; margin: 22px 0 0; }
.hero-h1 em { font-style: italic; color: var(--brand); }
.hero-sub { font-family: var(--font-serif); font-size: clamp(19px, 2vw, 23px); line-height: 1.5; color: var(--ink-600); max-width: 42ch; margin-top: 22px; }
.hero-cta { display:flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.hero-meta { display:flex; gap: 30px; margin-top: 38px; flex-wrap:wrap; }
.hero-meta .hm { display:flex; flex-direction:column; gap:3px; }
.hero-meta .hm .n { font-family: var(--font-display); font-size: 32px; color: var(--ink-900); line-height:1; }
.hero-meta .hm .l { font-family: var(--font-sans); font-size: 11px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-500); }
.hero-meta .div { width:1px; background: var(--line-strong); align-self:stretch; }

.hero-media { position: relative; }
.frame { position: relative; aspect-ratio: 4/5; border: 1px solid var(--line-strong); background: linear-gradient(135deg, var(--bone), var(--paper)); overflow: hidden; }
.frame::after { content:""; position:absolute; inset: 11px; border: 1px solid var(--ink-300); opacity:.5; pointer-events:none; }
.frame .ph { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; color: var(--ink-400); padding: 20px; text-align:center; }
.frame .ph .ico { width: 46px; height:46px; color: var(--ink-300); stroke-width:1.2; }
.frame .ph .cap { font-family: var(--font-sans); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; }
.hero-float { position:absolute; left: -26px; bottom: 34px; background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow-md); padding: 18px 22px; display:flex; align-items:center; gap:15px; max-width: 270px; }
.hero-float .seal { width:46px;height:46px;border-radius:50%;border:1px solid var(--ink-900);display:flex;align-items:center;justify-content:center;flex:none; }
.hero-float .seal svg{ width:22px;height:22px;color:var(--ink-900);stroke-width:1.4; }
.hero-float .big { font-family: var(--font-display); font-size: 30px; line-height: 1; color: var(--ink-900); }
.hero-float .lbl { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.08em; line-height:1.4; text-transform: uppercase; color: var(--ink-500); }

/* Centered hero variant (tweak) */
body[data-hero="centered"] .hero .ds-wrap { grid-template-columns: 1fr; justify-items:center; text-align:center; gap: 44px; }
body[data-hero="centered"] .hero-text { max-width: 760px; }
body[data-hero="centered"] .eyebrow.center::before { display:none; }
body[data-hero="centered"] .hero-sub { margin-left:auto; margin-right:auto; }
body[data-hero="centered"] .hero-cta, body[data-hero="centered"] .hero-meta { justify-content:center; }
body[data-hero="centered"] .hero-media { max-width: 900px; width:100%; }
body[data-hero="centered"] .frame { aspect-ratio: 16/7; }
body[data-hero="centered"] .hero-float { left: 24px; }

@media (max-width: 860px){
  .hero .ds-wrap{ grid-template-columns: 1fr; }
  .hero-media{ max-width: 460px; }
  .hero-float{ left: auto; right: -10px; }
}

/* ---------- Trust band ---------- */
.ds-trust { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--paper); }
.ds-trust .ds-wrap { display:grid; grid-template-columns: repeat(4, 1fr); }
.trust-item { display:flex; align-items:center; gap: 15px; padding: 28px 28px; border-right: 1px solid var(--line); }
.trust-item:last-child { border-right: none; }
.trust-item svg { width: 28px; height: 28px; color: var(--ink-900); flex: none; stroke-width: 1.3; }
.trust-item .ti-t { font-family: var(--font-display); font-size: 19px; color: var(--ink-900); line-height: 1.1; }
.trust-item .ti-s { font-family: var(--font-sans); font-size: 12px; color: var(--ink-500); margin-top: 3px; }
@media (max-width: 860px){ .ds-trust .ds-wrap{ grid-template-columns: 1fr 1fr; } .trust-item:nth-child(2){border-right:none;} .trust-item:nth-child(1),.trust-item:nth-child(2){ border-bottom:1px solid var(--line);} }
@media (max-width: 520px){ .ds-trust .ds-wrap{ grid-template-columns: 1fr; } .trust-item{ border-right:none; border-bottom:1px solid var(--line);} .trust-item:last-child{border-bottom:none;} }

/* ---------- Section heads ---------- */
.sec { padding: var(--sec-pad) 0; }
.sec-head { display:flex; flex-direction:column; gap: 18px; margin-bottom: clamp(36px, 5vw, 58px); }
.sec-head.center { text-align:center; align-items:center; }
.sec-head h2 { font-family: var(--font-display); font-weight: 500; color: var(--ink-900); font-size: clamp(32px, 4vw, 52px); line-height: 1.04; letter-spacing: -0.01em; max-width: 20ch; }
.sec-head p { font-family: var(--font-serif); font-size: 20px; color: var(--ink-600); max-width: 56ch; line-height: 1.5; }
.sec-head.center p { margin-inline:auto; }

/* ---------- Services ---------- */
.services { display:grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.svc { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(28px, 3vw, 40px); display:flex; flex-direction:column; gap: 16px; position:relative; transition: background var(--dur) var(--ease); }
.svc:hover { background: var(--bone); }
.svc .ic { width: 40px; height: 40px; color: var(--ink-900); stroke-width:1.3; }
.svc .no { position:absolute; top: clamp(24px,3vw,34px); right: clamp(24px,3vw,34px); font-family: var(--font-display); font-size: 15px; color: var(--ink-300); letter-spacing:.05em; }
.svc h3 { font-family: var(--font-display); font-size: clamp(21px, 2.2vw, 26px); color: var(--ink-900); line-height: 1.12; }
.svc p { font-family: var(--font-sans); font-size: 14.5px; color: var(--ink-600); line-height: 1.62; }
.svc .more { margin-top: auto; font-family: var(--font-sans); font-size: 11px; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-900); display:inline-flex; align-items:center; gap:8px; padding-top: 8px; }
.svc .more svg { width:15px;height:15px; transition: transform var(--dur) var(--ease); }
.svc:hover .more svg { transform: translateX(4px); }
@media (max-width: 900px){ .services{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .services{ grid-template-columns: 1fr; } }

/* ---------- Process ---------- */
.ds-process { background: var(--bone); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.steps { display:grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.6vw, 40px); }
.step { display:flex; flex-direction:column; gap: 13px; }
.step .num { font-family: var(--font-display); font-weight: 500; font-size: 30px; color: var(--brand); line-height:1; }
.step .rule { height:1px; background: var(--line-strong); }
.step h3 { font-family: var(--font-display); font-size: 22px; color: var(--ink-900); line-height: 1.12; }
.step p { font-family: var(--font-sans); font-size: 14px; color: var(--ink-600); line-height: 1.62; }
@media (max-width: 980px){ .steps{ grid-template-columns: 1fr 1fr; gap: 34px 28px; } }
@media (max-width: 520px){ .steps{ grid-template-columns: 1fr; } }

/* ---------- Before / After ---------- */
.ba-grid { display:grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(32px,5vw,64px); align-items:center; }
.ba { position: relative; aspect-ratio: 16/10; border:1px solid var(--line-strong); overflow:hidden; user-select:none; background: var(--bone); }
.ba .layer { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; }
.ba .after { background: linear-gradient(135deg, #ececec, #fafafa); color: var(--ink-400); }
.ba .before { background: linear-gradient(135deg, #c9c9c9, #e2e2e2); color: var(--ink-600); clip-path: inset(0 50% 0 0); }
.ba .layer .ico { width:42px;height:42px;stroke-width:1.2; }
.ba .layer .tag { position:absolute; top:16px; font-family: var(--font-sans); font-size: 10px; letter-spacing:.22em; text-transform:uppercase; padding: 6px 12px; background: var(--ink-900); color: var(--ivory); }
.ba .before .tag { left:16px; }
.ba .after .tag { right:16px; background: var(--paper); color: var(--ink-900); border:1px solid var(--line); }
.ba .cap { font-family: var(--font-sans); font-size: 10px; letter-spacing:.2em; text-transform:uppercase; }
.ba-handle { position:absolute; top:0; bottom:0; left:50%; width:2px; background: var(--ivory); transform: translateX(-50%); box-shadow: 0 0 0 1px rgba(0,0,0,.15); z-index:3; }
.ba-handle .grip { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:42px; height:42px; border-radius:50%; background: var(--ivory); border:1px solid var(--line-strong); display:flex; align-items:center; justify-content:center; box-shadow: var(--shadow-sm); cursor:ew-resize; }
.ba-handle .grip svg { width:20px; height:20px; color: var(--ink-700); }
.ba-range { position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; z-index:4; margin:0; }
.ba-aside h3 { font-family: var(--font-display); font-weight:500; font-size: clamp(26px,3vw,38px); color: var(--ink-900); line-height:1.08; }
.ba-aside p { font-family: var(--font-sans); font-size: 15.5px; color: var(--ink-600); line-height:1.65; margin-top: 18px; max-width: 44ch; }
.ba-aside .meta { margin-top: 24px; display:flex; gap: 26px; flex-wrap:wrap; }
.ba-aside .meta .m .n { font-family: var(--font-display); font-size: 26px; color: var(--ink-900); }
.ba-aside .meta .m .l { font-family: var(--font-sans); font-size: 11px; letter-spacing:.12em; text-transform:uppercase; color: var(--ink-500); margin-top:3px; }
@media (max-width: 820px){ .ba-grid{ grid-template-columns:1fr; } }

/* ---------- Projects ---------- */
.proj-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px,2.4vw,30px); }
.proj { display:flex; flex-direction:column; gap: 0; cursor:pointer; }
.proj .pic { position:relative; aspect-ratio: 4/3; border:1px solid var(--line-strong); background: linear-gradient(135deg, var(--bone), var(--paper)); overflow:hidden; transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.proj:hover .pic { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.proj .pic .ph { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color: var(--ink-300); }
.proj .pic .ph svg { width:38px;height:38px;stroke-width:1.2; }
.proj .pic .chip { position:absolute; left:14px; top:14px; font-family: var(--font-sans); font-size: 9.5px; letter-spacing:.18em; text-transform:uppercase; white-space:nowrap; background: var(--ink-900); color: var(--ivory); padding: 6px 11px; z-index:2; }
/* Project status badge (top-right) */
.proj .status { position:absolute; right:14px; top:14px; z-index:2; display:inline-flex; align-items:center; gap:6px; font-family: var(--font-sans); font-size: 9.5px; letter-spacing:.16em; text-transform:uppercase; font-weight:500; padding: 6px 10px; border-radius: 999px; }
.proj .status.done { background: rgba(255,255,255,.92); color: var(--ink-700); border:1px solid var(--line); }
.proj .status.ongoing { background: var(--ink-900); color: var(--ivory); }
.proj .status .d { width:6px; height:6px; border-radius:50%; background: var(--success); }
.proj .status.done .d { background: var(--ink-400); }
a.proj { text-decoration:none; color:inherit; }
.proj .info { padding: 18px 2px 4px; display:flex; align-items:flex-start; justify-content:space-between; gap:14px; border-top: 1px solid transparent; }
.proj h4 { font-family: var(--font-display); font-size: 21px; color: var(--ink-900); line-height:1.15; }
.proj .loc { font-family: var(--font-sans); font-size: 12.5px; color: var(--ink-500); margin-top:5px; display:flex; align-items:center; gap:6px; }
.proj .loc svg { width:13px;height:13px; stroke-width:1.5; }
.proj .yr { font-family: var(--font-display); font-size: 17px; color: var(--ink-400); flex:none; }
@media (max-width: 900px){ .proj-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .proj-grid{ grid-template-columns: 1fr; } }

/* ---------- Materials / brands ---------- */
.materials { display:grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.materials .m { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 30px 14px; text-align:center; font-family: var(--font-display); font-size: 21px; color: var(--ink-700); letter-spacing: 0.01em; transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.materials .m:hover { background: var(--ink-900); color: var(--ivory); }
@media (max-width: 860px){ .materials{ grid-template-columns: repeat(3,1fr); } }
@media (max-width: 520px){ .materials{ grid-template-columns: repeat(2,1fr); } }

/* ---------- Stats band (ink full-bleed) ---------- */
.ds-stats { background: var(--ink-900); color: var(--ivory); }
.ds-stats .ds-wrap { padding: clamp(56px,7vw,96px) var(--gutter); }
.stats-head { text-align:center; margin-bottom: clamp(40px,5vw,60px); }
.stats-head .eyebrow { color: var(--ink-300); justify-content:center; }
.stats-head h2 { font-family: var(--font-display); font-weight:500; font-size: clamp(28px,3.4vw,44px); color: var(--ivory); margin-top:16px; }
.stats-grid { display:grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.stat { text-align:center; padding: 18px 10px; border-left: 1px solid rgba(255,255,255,.12); }
.stat:first-child { border-left:none; }
.stat .n { font-family: var(--font-display); font-weight:500; font-size: clamp(44px,5vw,68px); line-height:1; color: var(--ivory); }
.stat .n .suf { color: var(--ink-300); }
.stat .l { font-family: var(--font-sans); font-size: 12px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-300); margin-top: 14px; }
@media (max-width: 720px){ .stats-grid{ grid-template-columns: 1fr 1fr; gap: 36px 12px; } .stat:nth-child(3){ border-left:none; } }

/* ---------- Testimonials ---------- */
.testi-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(18px,2.2vw,26px); }
.tcard { border:1px solid var(--line); background: var(--paper); padding: clamp(26px,3vw,38px); display:flex; flex-direction:column; gap: 18px; transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tcard:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.tcard .stars { display:flex; gap:4px; color: var(--ink-900); }
.tcard .stars svg { width:16px; height:16px; }
.tcard blockquote { font-family: var(--font-serif); font-size: 20px; line-height: 1.45; color: var(--ink-800); margin:0; }
.tcard .who { display:flex; align-items:center; gap:13px; margin-top: auto; }
.tcard .who .av { width:42px;height:42px;border-radius:50%; background: var(--bone); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-family: var(--font-display); font-size:17px; color: var(--ink-700); flex:none; }
.tcard .who .nm { font-family: var(--font-sans); font-size: 14px; font-weight:500; color: var(--ink-900); }
.tcard .who .pl { font-family: var(--font-sans); font-size: 12px; color: var(--ink-500); margin-top:2px; }
@media (max-width: 860px){ .testi-grid{ grid-template-columns: 1fr; max-width:560px; margin-inline:auto; } }

/* ---------- Form / Inspection ---------- */
.ds-form-sec { background: var(--bone); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.form-grid { display:grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(36px, 5vw, 76px); align-items: start; }
.form-aside h2 { font-family: var(--font-display); font-weight:500; color: var(--ink-900); font-size: clamp(30px, 3.6vw, 48px); line-height: 1.04; letter-spacing:-.01em; margin-top: 18px; }
.form-aside p { font-family: var(--font-serif); font-size: 19px; color: var(--ink-600); line-height: 1.55; margin-top: 18px; max-width: 40ch; }
.aside-list { list-style:none; padding:0; margin: 30px 0 0; display:flex; flex-direction:column; gap: 16px; }
.aside-list li { display:flex; gap: 13px; align-items:flex-start; font-family: var(--font-sans); font-size: 15px; color: var(--ink-700); }
.aside-list svg { width:19px; height:19px; color: var(--ink-900); flex:none; margin-top:1px; stroke-width:1.5; }
.aside-call { margin-top: 34px; padding-top: 28px; border-top: 1px solid var(--line-strong); }
.aside-call .lbl { font-family: var(--font-sans); font-size: 11px; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-500); }
.aside-call .row { display:flex; gap:12px; margin-top: 14px; flex-wrap:wrap; }
.btn-call { background: var(--paper); color: var(--ink-900); border-color: var(--ink-900); }
.btn-call:hover { background: var(--ink-900); color: var(--ivory); }
.btn-wa { background: var(--paper); color: var(--ink-900); border-color: var(--line-strong); }
.btn-wa:hover { border-color: var(--ink-900); }

.form-card { background: var(--paper); border: 1px solid var(--line); box-shadow: var(--shadow-md); padding: clamp(26px, 3.4vw, 44px); }
.fc-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 22px 22px; }
.fc-span { grid-column: 1 / -1; }
.field { display:flex; flex-direction:column; gap: 8px; }
.field label { font-family: var(--font-sans); font-size: 12px; font-weight:500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-600); }
.field label .req { color: var(--brand); }
.control { font-family: var(--font-sans); font-size: 16px; color: var(--ink-900); background: var(--cloud); border: 1px solid var(--line-strong); border-radius: 2px; height: 52px; padding: 0 15px; width: 100%; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.control::placeholder { color: var(--ink-400); }
.control:hover { border-color: var(--ink-600); }
.control:focus { outline: none; border-color: var(--ink-900); box-shadow: 0 0 0 3px var(--brand-wash); }
textarea.control { height:auto; min-height: 110px; padding: 13px 15px; line-height: 1.5; resize: vertical; }
.sel-wrap { position: relative; }
.sel-wrap select.control { appearance: none; -webkit-appearance:none; padding-right: 42px; cursor:pointer; }
.sel-wrap .chev { position:absolute; right:15px; top:18px; width:16px; height:16px; pointer-events:none; color: var(--ink-500); }

.consent { display:flex; gap: 11px; align-items:flex-start; font-family: var(--font-sans); font-size: 13px; color: var(--ink-600); line-height: 1.5; }
.consent input { margin-top: 2px; accent-color: var(--ink-900); width: 16px; height: 16px; }
.form-foot { display:flex; align-items:center; justify-content:space-between; gap: 18px; margin-top: 6px; flex-wrap: wrap; }
.form-note { font-family: var(--font-sans); font-size: 12px; color: var(--ink-500); display:flex; align-items:center; gap:8px; }
.form-note svg { width: 15px; height:15px; color: var(--ink-900); }
@media (max-width: 880px){ .form-grid{ grid-template-columns: 1fr; } .fc-grid{ grid-template-columns: 1fr; } }

.thanks { display:none; flex-direction:column; align-items:center; text-align:center; gap: 18px; padding: clamp(30px, 5vw, 60px) 20px; }
.thanks.show { display:flex; }
.thanks .seal { width: 74px; height: 74px; border-radius: 50%; border: 1px solid var(--ink-900); display:flex; align-items:center; justify-content:center; color: var(--ink-900); }
.thanks .seal svg { width: 34px; height: 34px; stroke-width: 1.2; }
.thanks h3 { font-family: var(--font-display); font-size: 34px; color: var(--ink-900); }
.thanks p { font-family: var(--font-serif); font-size: 19px; color: var(--ink-600); max-width: 42ch; line-height: 1.5; }

/* ---------- FAQ ---------- */
.faq { max-width: var(--container-narrow); margin: 0 auto; border-top: 1px solid var(--line); }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { list-style: none; cursor: pointer; display:flex; align-items:center; justify-content:space-between; gap: 20px; padding: 26px 4px; font-family: var(--font-display); font-size: clamp(19px, 2.2vw, 24px); color: var(--ink-900); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary .ic { width: 22px; height: 22px; flex:none; position: relative; }
.faq summary .ic::before, .faq summary .ic::after { content:""; position:absolute; background: var(--ink-900); transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.faq summary .ic::before { left:0; right:0; top:50%; height:1px; transform: translateY(-50%); }
.faq summary .ic::after { top:0; bottom:0; left:50%; width:1px; transform: translateX(-50%); }
.faq details[open] summary .ic::after { opacity: 0; }
.faq .ans { padding: 0 4px 28px; font-family: var(--font-sans); font-size: 16px; color: var(--ink-600); line-height: 1.65; max-width: 70ch; }

/* ---------- CTA strip ---------- */
.ds-cta { background: var(--paper); }
.ds-cta .inner { border:1px solid var(--ink-900); padding: clamp(40px,6vw,72px) clamp(28px,5vw,72px); display:flex; align-items:center; justify-content:space-between; gap: 36px; flex-wrap:wrap; }
.ds-cta h2 { font-family: var(--font-display); font-weight:500; font-size: clamp(28px,3.6vw,46px); color: var(--ink-900); line-height:1.05; max-width: 18ch; }
.ds-cta p { font-family: var(--font-serif); font-size: 19px; color: var(--ink-600); margin-top: 14px; }

/* ---------- Footer ---------- */
.ds-footer { background: var(--ink-900); color: var(--ink-300); }
.ds-footer .ds-wrap { padding: clamp(56px, 7vw, 88px) var(--gutter) 36px; }
.foot-top { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.foot-brand .fb-word { font-family: var(--font-display); font-weight: 500; font-size: 27px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ivory); }
.foot-brand .fb-tag { font-family: var(--font-sans); font-size: 9.5px; letter-spacing: 0.42em; text-transform: uppercase; color: var(--ink-400); margin-top: 12px; }
.foot-brand p { font-family: var(--font-serif); font-size: 17px; color: var(--ink-300); margin-top: 22px; max-width: 34ch; line-height: 1.5; }
.foot-col h4 { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-200, #d8d8d8); margin: 0 0 18px; font-weight: 500; }
.foot-col a, .foot-col .li { display:block; font-family: var(--font-sans); font-size: 14px; color: var(--ink-300); padding: 7px 0; transition: color var(--dur) var(--ease); }
.foot-col a:hover { color: var(--ivory); }
.foot-bot { display:flex; align-items:center; justify-content:space-between; gap: 16px; padding-top: 26px; font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-400); flex-wrap: wrap; }
.foot-bot .soc { display:flex; gap: 22px; }
.foot-bot a:hover { color: var(--ivory); }
@media (max-width: 860px){ .foot-top{ grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 480px){ .foot-top{ grid-template-columns: 1fr; } }

/* ---------- Entrance ---------- */
/* Display headline weight is driven by the active typeface (Tweaks). */
.hero-h1, .sec-head h2, .form-aside h2, .ds-cta h2, .stats-head h2, .ba-aside h3, .ba-aside h3, .thanks h3 { font-weight: var(--display-weight, 500); }
/* Content is always visible in every render context (per design-system guidance);
   no opacity/transform entrance that could get stuck in throttled contexts. */
.reveal { opacity: 1; }

/* ============================================================
   INNER PAGES  (services, process, projects, results, contact, legal)
   ============================================================ */
.foot-bot a { color: var(--ink-300); }
.foot-legal { display:flex; gap: 18px; flex-wrap:wrap; }
.foot-legal a { color: var(--ink-400); transition: color var(--dur) var(--ease); }
.foot-legal a:hover { color: var(--ivory); }
@media (max-width: 680px){ .foot-bot{ flex-direction:column; align-items:flex-start; gap:18px; } }

/* ---------- Page head band ---------- */
.page-head { background: var(--bone); border-bottom: 1px solid var(--line); }
.page-head .ds-wrap { padding: clamp(46px, 7vw, 92px) var(--gutter) clamp(40px, 6vw, 72px); }
.crumbs { display:flex; align-items:center; gap: 9px; font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 24px; }
.crumbs a { color: var(--ink-500); transition: color var(--dur) var(--ease); }
.crumbs a:hover { color: var(--ink-900); }
.crumbs .sep { color: var(--ink-300); }
.page-head h1 { font-family: var(--font-display); font-weight: var(--display-weight, 500); color: var(--ink-900); font-size: clamp(40px, 5.4vw, 76px); line-height: 1.03; letter-spacing: -0.015em; max-width: 18ch; }
.page-head h1 em { font-style: italic; color: var(--brand); }
.page-head .lede { font-family: var(--font-serif); font-size: clamp(19px, 2vw, 23px); line-height: 1.5; color: var(--ink-600); max-width: 56ch; margin-top: 22px; }

/* ---------- Generic two-column content ---------- */
.split { display:grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(36px,5vw,72px); align-items:start; }
.split.narrow { grid-template-columns: 1fr 0.7fr; }
@media (max-width: 880px){ .split, .split.narrow { grid-template-columns: 1fr; } }

/* Aside fact card (service detail / sidebars) */
.fact-card { border: 1px solid var(--line); background: var(--paper); box-shadow: var(--shadow-sm); padding: clamp(24px,3vw,36px); position: sticky; top: calc(var(--ds-head-h) + 22px); }
.fact-card h3 { font-family: var(--font-display); font-size: 24px; color: var(--ink-900); }
.fact-card .facts { list-style:none; padding:0; margin: 20px 0 0; display:flex; flex-direction:column; }
.fact-card .facts li { display:flex; justify-content:space-between; gap: 16px; padding: 13px 0; border-bottom: 1px solid var(--line); font-family: var(--font-sans); font-size: 14px; }
.fact-card .facts li:last-child { border-bottom:none; }
.fact-card .facts .k { color: var(--ink-500); }
.fact-card .facts .v { color: var(--ink-900); font-weight: 500; text-align:right; }
.fact-card .cta { margin-top: 24px; display:flex; flex-direction:column; gap: 10px; }

/* ---------- Prose (legal & long-form) ---------- */
.prose { max-width: var(--container-text); }
.prose > * + * { margin-top: 18px; }
.prose h2 { font-family: var(--font-display); font-weight: var(--display-weight, 500); font-size: clamp(24px, 3vw, 34px); color: var(--ink-900); line-height: 1.12; margin-top: 48px; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-family: var(--font-display); font-size: 21px; color: var(--ink-900); margin-top: 30px; }
.prose p, .prose li { font-family: var(--font-sans); font-size: 16px; line-height: 1.7; color: var(--ink-700); }
.prose ul, .prose ol { margin: 14px 0; padding-left: 22px; display:flex; flex-direction:column; gap: 9px; }
.prose li { padding-left: 4px; }
.prose a { color: var(--ink-900); border-bottom: 1px solid var(--line-strong); transition: border-color var(--dur) var(--ease); }
.prose a:hover { border-color: var(--ink-900); }
.prose strong { color: var(--ink-900); font-weight: 600; }
.prose .updated { font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.04em; color: var(--ink-500); }
.legal-note { border: 1px solid var(--line); background: var(--bone); padding: 18px 22px; font-family: var(--font-sans); font-size: 13.5px; line-height: 1.6; color: var(--ink-600); display:flex; gap: 12px; align-items:flex-start; }
.legal-note svg { width: 18px; height: 18px; flex:none; margin-top: 1px; color: var(--ink-900); stroke-width: 1.4; }

/* Legal layout with section index */
.legal-grid { display:grid; grid-template-columns: 240px 1fr; gap: clamp(36px,5vw,72px); align-items:start; }
.legal-index { position: sticky; top: calc(var(--ds-head-h) + 22px); }
.legal-index .lbl { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 16px; }
.legal-index ol { list-style:none; counter-reset: li; padding:0; margin:0; display:flex; flex-direction:column; }
.legal-index a { display:block; counter-increment: li; font-family: var(--font-sans); font-size: 13.5px; color: var(--ink-600); padding: 8px 0; border-top: 1px solid var(--line); transition: color var(--dur) var(--ease); }
.legal-index a::before { content: counter(li, decimal-leading-zero) "  "; color: var(--ink-300); }
.legal-index a:hover { color: var(--ink-900); }
@media (max-width: 880px){ .legal-grid{ grid-template-columns: 1fr; } .legal-index{ position: static; } .legal-index ol{ display:none; } }

/* ---------- Feature rows (process / why-us) ---------- */
.feature { display:grid; grid-template-columns: 64px 1fr; gap: 24px; padding: 30px 0; border-top: 1px solid var(--line); }
.feature:last-child { border-bottom: 1px solid var(--line); }
.feature .fnum { font-family: var(--font-display); font-weight: var(--display-weight,500); font-size: 30px; color: var(--brand); line-height: 1; }
.feature .ficon { width: 44px; height: 44px; color: var(--ink-900); stroke-width: 1.3; }
.feature h3 { font-family: var(--font-display); font-size: clamp(22px,2.4vw,28px); color: var(--ink-900); line-height: 1.12; }
.feature p { font-family: var(--font-sans); font-size: 15.5px; color: var(--ink-600); line-height: 1.65; margin-top: 10px; max-width: 64ch; }
@media (max-width: 560px){ .feature{ grid-template-columns: 1fr; gap: 12px; } }

/* Checklist */
.checks { list-style:none; padding:0; margin: 24px 0 0; display:flex; flex-direction:column; gap: 14px; }
.checks li { display:flex; gap: 13px; align-items:flex-start; font-family: var(--font-sans); font-size: 16px; color: var(--ink-700); line-height: 1.5; }
.checks svg { width: 20px; height: 20px; color: var(--ink-900); flex:none; margin-top: 2px; stroke-width: 1.5; }

/* Section intro (left-aligned) reused on inner pages */
.lead-serif { font-family: var(--font-serif); font-size: clamp(20px,2.4vw,26px); line-height: 1.5; color: var(--ink-700); max-width: 60ch; }
.body-copy { font-family: var(--font-sans); font-size: 16px; line-height: 1.72; color: var(--ink-700); max-width: 64ch; }
.body-copy + .body-copy { margin-top: 18px; }

/* ============================================================
   PROJECT FILTER + DETAIL (gallery first, details at bottom)
   ============================================================ */
.proj-filter { display:flex; gap: 8px; flex-wrap:wrap; margin-bottom: 30px; }
.proj-filter button { font-family: var(--font-sans); font-size: 12px; letter-spacing:.1em; text-transform:uppercase; font-weight:500; padding: 10px 18px; border:1px solid var(--line-strong); background: var(--paper); color: var(--ink-700); border-radius: 999px; cursor:pointer; transition: all var(--dur) var(--ease); }
.proj-filter button:hover { border-color: var(--ink-900); }
.proj-filter button.on { background: var(--ink-900); color: var(--ivory); border-color: var(--ink-900); }

/* Generic image placeholder */
.imgph { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; color: var(--ink-300); text-align:center; padding:16px; }
.imgph svg { width: 40px; height: 40px; stroke-width:1.2; }
.imgph .cap { font-family: var(--font-sans); font-size: 10px; letter-spacing:.2em; text-transform:uppercase; color: var(--ink-400); }

/* Project detail */
.pj-top { margin-bottom: clamp(24px,3vw,38px); }
.pj-top h1 { font-family: var(--font-display); font-weight: var(--display-weight,500); color: var(--ink-900); font-size: clamp(36px,5vw,68px); line-height:1.03; letter-spacing:-.015em; margin-top: 14px; max-width: 18ch; }
.pj-top h1 em { font-style:italic; color: var(--brand); }
.pj-meta { display:flex; align-items:center; gap: 16px; flex-wrap:wrap; margin-top: 18px; font-family: var(--font-sans); font-size: 14px; color: var(--ink-600); }
.pj-meta .mi { display:inline-flex; align-items:center; gap:7px; }
.pj-meta .mi svg { width:15px; height:15px; stroke-width:1.5; color: var(--ink-900); }
.pj-meta .sep { color: var(--line-strong); }
.pj-status { display:inline-flex; align-items:center; gap:7px; font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:500; padding:6px 12px; border-radius:999px; }
.pj-status.ongoing { background: var(--ink-900); color: var(--ivory); }
.pj-status.done { background: var(--bone); color: var(--ink-700); border:1px solid var(--line); }
.pj-status .d { width:6px;height:6px;border-radius:50%;background:var(--success); }
.pj-status.done .d { background: var(--ink-400); }

.pj-gallery { display:grid; gap: 14px; }
.pj-main { position:relative; aspect-ratio: 16/9; border:1px solid var(--line-strong); background: linear-gradient(135deg, var(--bone), var(--paper)); overflow:hidden; }
.pj-thumbs { display:grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.pj-thumb { position:relative; aspect-ratio: 4/3; border:1px solid var(--line-strong); background: linear-gradient(135deg, var(--bone), var(--paper)); overflow:hidden; }
@media (max-width: 640px){ .pj-thumbs{ grid-template-columns: 1fr 1fr; } }

.pj-detail { background: var(--bone); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.pj-client { font-family: var(--font-sans); font-size: 13px; letter-spacing:.04em; color: var(--ink-500); margin-top: 12px; }
.pj-section-head { display:flex; flex-direction:column; gap: 14px; margin-bottom: 24px; }
.pj-section-head h2 { font-family: var(--font-display); font-weight: var(--display-weight,500); font-size: clamp(26px,3vw,40px); color: var(--ink-900); line-height:1.08; }
.pj-map { width:100%; height: clamp(280px,40vw,420px); border:1px solid var(--line-strong); display:block; }
.ba-tags { display:flex; gap:18px; margin-top:14px; font-family: var(--font-sans); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color: var(--ink-500); }
.ba-tags .bt { display:inline-flex; align-items:center; gap:7px; }
.ba-tags .sw { width:12px; height:12px; border:1px solid var(--line-strong); }
.ba-tags .sw.b { background: linear-gradient(135deg,#c9c9c9,#e2e2e2); }
.ba-tags .sw.a { background: linear-gradient(135deg,#ececec,#fafafa); }

/* ============================================================
   LIVE CHAT WIDGET + FLOATING BUTTON  (built by dryshield-app.js)
   ============================================================ */
.dry-fab {
  position: fixed; right: clamp(16px,3vw,28px); bottom: clamp(16px,3vw,28px); z-index: 900;
  width: 60px; height: 60px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--ink-900); color: var(--ivory); display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md); transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.dry-fab:hover { transform: translateY(-3px); background: var(--ink-700); box-shadow: var(--shadow-lg); }
.dry-fab svg { width: 26px; height: 26px; stroke-width: 1.5; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); }
.dry-fab .ic-close { position: absolute; opacity: 0; transform: rotate(-90deg); }
.dry-fab.open .ic-chat { opacity: 0; transform: rotate(90deg); }
.dry-fab.open .ic-close { opacity: 1; transform: rotate(0); }
.dry-fab .dot { position: absolute; top: 12px; right: 12px; width: 9px; height: 9px; border-radius: 50%; background: var(--success); border: 2px solid var(--ink-900); }
.dry-fab .badge { position: absolute; top: -4px; right: -4px; min-width: 22px; height: 22px; padding: 0 6px; border-radius: 11px; background: var(--error); color: #fff; font-family: var(--font-sans); font-size: 12px; font-weight: 600; display: none; align-items: center; justify-content: center; }
.dry-fab.has-unread .badge { display: flex; }
@media print { .dry-fab, .dry-chat { display: none !important; } }

.dry-chat {
  position: fixed; right: clamp(16px,3vw,28px); bottom: calc(clamp(16px,3vw,28px) + 76px); z-index: 901;
  width: min(380px, calc(100vw - 32px)); max-height: min(620px, calc(100vh - 120px));
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; overflow: hidden;
  opacity: 0; transform: translateY(12px) scale(.98); pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.dry-chat.open { opacity: 1; transform: none; pointer-events: auto; }

.dry-chat .dc-head { background: var(--ink-900); color: var(--ivory); padding: 18px 20px; display: flex; align-items: center; gap: 13px; }
.dry-chat .dc-avatar { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; flex: none; }
.dry-chat .dc-avatar svg { width: 20px; height: 20px; color: var(--ivory); stroke-width: 1.5; }
.dry-chat .dc-title { font-family: var(--font-display); font-weight: var(--display-weight,500); font-size: 18px; line-height: 1.1; }
.dry-chat .dc-sub { font-family: var(--font-sans); font-size: 11.5px; letter-spacing: .04em; color: var(--ink-300); margin-top: 3px; display: flex; align-items: center; gap: 6px; }
.dry-chat .dc-sub .live { width: 7px; height: 7px; border-radius: 50%; background: var(--success); }
.dry-chat .dc-x { margin-left: auto; background: none; border: none; color: var(--ink-300); cursor: pointer; padding: 4px; display: flex; transition: color var(--dur) var(--ease); }
.dry-chat .dc-x:hover { color: var(--ivory); }
.dry-chat .dc-x svg { width: 20px; height: 20px; stroke-width: 1.6; }

.dry-chat .dc-body { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 12px; background: var(--bone); }
.dc-msg { max-width: 84%; font-family: var(--font-sans); font-size: 14.5px; line-height: 1.5; padding: 11px 14px; border-radius: 12px; }
.dc-msg.bot { align-self: flex-start; background: var(--paper); color: var(--ink-800); border: 1px solid var(--line); border-bottom-left-radius: 3px; }
.dc-msg.user { align-self: flex-end; background: var(--ink-900); color: var(--ivory); border-bottom-right-radius: 3px; }
.dc-msg .t { display: block; font-size: 10px; letter-spacing: .04em; margin-top: 6px; opacity: .55; }
.dc-time { align-self: center; font-family: var(--font-sans); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-400); margin: 4px 0; }

.dc-quick { display: flex; flex-wrap: wrap; gap: 8px; }
.dc-quick button { font-family: var(--font-sans); font-size: 13px; color: var(--ink-800); background: var(--paper); border: 1px solid var(--line-strong); border-radius: 999px; padding: 8px 14px; cursor: pointer; transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.dc-quick button:hover { background: var(--ink-900); color: var(--ivory); border-color: var(--ink-900); }

.dc-notify { display: flex; gap: 8px; padding: 10px 14px; background: var(--paper); border: 1px solid var(--line); border-radius: 10px; align-items: center; }
.dc-notify .nt { font-family: var(--font-sans); font-size: 12.5px; color: var(--ink-600); line-height: 1.4; }
.dc-notify a { font-weight: 500; color: var(--ink-900); white-space: nowrap; border-bottom: 1px solid var(--accent); }

/* Pre-chat + input */
.dry-chat .dc-gate { padding: 18px 20px; border-top: 1px solid var(--line); background: var(--paper); display: flex; flex-direction: column; gap: 12px; }
.dry-chat .dc-gate .lab { font-family: var(--font-sans); font-size: 12.5px; color: var(--ink-600); line-height: 1.4; }
.dc-input-row { display: flex; gap: 10px; align-items: flex-end; padding: 14px; border-top: 1px solid var(--line); background: var(--paper); }
.dc-input-row textarea { flex: 1; resize: none; font-family: var(--font-sans); font-size: 14.5px; color: var(--ink-900); background: var(--cloud); border: 1px solid var(--line-strong); border-radius: var(--radius-sm); padding: 11px 13px; height: 44px; max-height: 110px; line-height: 1.4; transition: border-color var(--dur) var(--ease); }
.dc-input-row textarea:focus { outline: none; border-color: var(--ink-900); }
.dc-input-row input.dc-field { font-family: var(--font-sans); font-size: 14.5px; color: var(--ink-900); background: var(--cloud); border: 1px solid var(--line-strong); border-radius: var(--radius-sm); padding: 0 13px; height: 46px; width: 100%; transition: border-color var(--dur) var(--ease); }
.dc-input-row input.dc-field:focus { outline: none; border-color: var(--ink-900); }
.dc-send { flex: none; width: 44px; height: 44px; border-radius: var(--radius-sm); border: none; background: var(--ink-900); color: var(--ivory); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--dur) var(--ease); }
.dc-send:hover { background: var(--ink-700); }
.dc-send svg { width: 19px; height: 19px; stroke-width: 1.6; }
.dc-typing { display: flex; gap: 4px; align-self: flex-start; padding: 12px 14px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; border-bottom-left-radius: 3px; }
.dc-typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-400); animation: dc-bounce 1.2s infinite; }
.dc-typing span:nth-child(2){ animation-delay:.15s; } .dc-typing span:nth-child(3){ animation-delay:.3s; }
@keyframes dc-bounce { 0%,60%,100%{ transform: translateY(0); opacity:.5; } 30%{ transform: translateY(-5px); opacity:1; } }
