:root{
  --bg:#efe3d1;
  --bg-soft:#f7efe4;
  --surface:rgba(255,251,246,.9);
  --surface-strong:#fffaf2;
  --ink:#201814;
  --muted:#6d5d52;
  --line:rgba(76,53,38,.12);
  --shadow:0 24px 60px rgba(60,37,22,.12);
  --green:#7bc24f;
  --orange:#ff9d16;
  --red:#ff5648;
  --blue:#5d9bff;
  --off:#ef665e;
  --on:#67cb74;
  --call:#6ea8ff;
  --hero-serif:Georgia,"Times New Roman",serif;
  --sans:"Trebuchet MS","Segoe UI",Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.65), transparent 24%),
    radial-gradient(circle at bottom right, rgba(250,216,168,.35), transparent 28%),
    linear-gradient(180deg,#fff8ef 0,#f3e7d8 58%,#eadac7 100%);
  color:var(--ink);
  font-family:var(--sans);
}
body.site-page{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.72), transparent 24%),
    radial-gradient(circle at 78% 16%, rgba(255,227,177,.52), transparent 26%),
    linear-gradient(180deg,#fff9f0 0,#f5eadb 58%,#ead8c4 100%);
}
body.dashboard-page{
  background:
    radial-gradient(circle at 86% 8%, rgba(255,121,89,.18), transparent 24%),
    radial-gradient(circle at 10% 88%, rgba(123,194,79,.16), transparent 26%),
    linear-gradient(180deg, rgba(255,248,240,.96), rgba(240,228,214,.96)),
    repeating-linear-gradient(135deg, rgba(123,194,79,.08) 0 1px, transparent 1px 22px);
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}

.shell{min-height:100vh;padding:22px 22px 140px}
.page{
  width:min(1380px,100%);
  margin:0 auto;
}
body.site-page .page{
  position:relative;
  z-index:1;
}

.site-header,
.dashboard-header{
  position:sticky;
  top:14px;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 20px;
  border-radius:999px;
  background:rgba(255,249,242,.54);
  border:1px solid rgba(255,255,255,.48);
  box-shadow:0 18px 44px rgba(60,37,22,.10);
  backdrop-filter:blur(18px);
}
body.site-page .site-header{
  background:rgba(255,249,242,.36);
  border-color:rgba(255,255,255,.58);
  box-shadow:0 20px 44px rgba(60,37,22,.08);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-badge{
  width:46px;
  height:46px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,#ff7959,#da4329);
  color:#fff;
  font-size:18px;
  font-weight:800;
  letter-spacing:.08em;
}
.brand-copy strong{display:block;font-size:20px;letter-spacing:.04em}
.brand-copy span{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.site-nav{
  display:flex;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.site-nav a{
  font-size:13px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.site-nav a:hover{color:#b74f2c}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:3px solid rgba(255,157,22,.7);
  outline-offset:3px;
}

.dashboard-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.header-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(76,53,38,.12);
  background:#fff;
  color:var(--ink);
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:0 10px 24px rgba(60,37,22,.08);
  cursor:pointer;
}
.header-btn.primary{
  background:linear-gradient(180deg,#2f2922,#16120e);
  color:#fff;
}

.hero-grid,
.portal-grid,
.dashboard-main,
.detail-grid,
.booking-grid{
  display:grid;
  gap:22px;
  margin-top:24px;
}
.hero-grid{grid-template-columns:1.02fr .98fr}
.portal-grid{grid-template-columns:1fr 1fr}
.booking-grid{grid-template-columns:.95fr 1.05fr}
.dashboard-main{grid-template-columns:minmax(0,1fr)}
.detail-grid{grid-template-columns:minmax(0,1fr)}
body.dashboard-page .portal-grid{
  grid-template-columns:minmax(0,1fr);
}
body.site-page .hero-grid,
body.site-page .booking-grid{
  align-items:center;
  margin-top:34px;
}

.card,
.main-panel,
.drawer-panel,
.print-shell{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,252,247,.95), rgba(255,247,239,.88));
  border:1px solid rgba(255,255,255,.4);
  border-radius:30px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px);
}
.card,
.main-panel,
.drawer-panel{padding:28px}
.card::before,
.main-panel::before,
.drawer-panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:82px;
  background:linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,0));
  pointer-events:none;
}
body.site-page .card{
  overflow:visible;
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
  backdrop-filter:none;
}
body.site-page .card::before{
  display:none;
}
body.site-page .hero-copy{
  padding:18px 24px 18px 0;
}
body.site-page .visual-card,
body.site-page .market-scene,
body.site-page .story-card{
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,252,247,.92), rgba(255,246,237,.88));
  border:1px solid rgba(255,255,255,.52);
  border-radius:34px;
  box-shadow:0 28px 64px rgba(60,37,22,.12);
  backdrop-filter:blur(14px);
}
body.site-page .visual-card{
  padding:18px;
}
body.site-page .visual-card img{
  width:100%;
  border-radius:24px;
  object-fit:cover;
}
body.site-page .story-card{
  padding:28px;
}

.site-visual{
  min-height:720px;
  border-radius:34px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(255,250,242,.96) 0 34%, rgba(255,250,242,.28) 58%, rgba(255,250,242,.05) 100%),
    linear-gradient(120deg,#fff8ef 0,#f7e2c8 42%,#e8f0dc 100%);
}
.site-visual::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(90deg, transparent 0 66px, rgba(69,42,25,.08) 67px 68px),
    linear-gradient(90deg, transparent 0 50%, rgba(32,24,20,.08) 50% 100%);
  opacity:.7;
}
.site-visual::after{
  content:"";
  position:absolute;
  right:5%;
  top:12%;
  width:54%;
  height:52%;
  border-radius:26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.18)),
    repeating-linear-gradient(0deg, rgba(180,55,35,.22) 0 16px, rgba(123,194,79,.22) 16px 32px, rgba(255,157,22,.24) 32px 48px);
  border:1px solid rgba(76,53,38,.12);
  box-shadow:0 30px 80px rgba(60,37,22,.16);
}
.visual-copy{
  position:absolute;
  left:36px;
  top:42px;
  z-index:2;
  max-width:360px;
}
.visual-copy strong{
  display:block;
  font:400 46px/1.02 var(--hero-serif);
  margin-bottom:14px;
}
.visual-copy span{
  display:block;
  line-height:1.65;
  color:#40362f;
}
.produce-line{
  position:absolute;
  z-index:3;
  left:8%;
  right:6%;
  bottom:8%;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}
.produce-line i{
  display:block;
  min-height:118px;
  border-radius:28px 28px 16px 16px;
  background:
    radial-gradient(circle at 40% 24%, rgba(255,255,255,.7), transparent 26%),
    linear-gradient(180deg,#9fcb6a,#6d933c 58%,#c78342 59% 100%);
  border:1px solid rgba(76,53,38,.12);
  box-shadow:0 18px 44px rgba(60,37,22,.16);
}
.produce-line i:nth-child(2){background:linear-gradient(180deg,#e95b42,#b73327 58%,#c78342 59% 100%)}
.produce-line i:nth-child(3){background:linear-gradient(180deg,#f2cf61,#df9b2d 58%,#c78342 59% 100%)}
.produce-line i:nth-child(4){background:linear-gradient(180deg,#b78bd9,#8262ad 58%,#c78342 59% 100%)}
.produce-line i:nth-child(5){background:linear-gradient(180deg,#78b456,#4f7b35 58%,#c78342 59% 100%)}
.site-visual.staff::after{
  background:
    radial-gradient(circle at 50% 24%, #f6d3b3 0 10%, transparent 11%),
    radial-gradient(circle at 24% 32%, #f2c197 0 8%, transparent 9%),
    radial-gradient(circle at 76% 32%, #e7b388 0 8%, transparent 9%),
    linear-gradient(180deg,#263428 0 58%,#d7b28d 58% 100%);
}
.site-visual.service::after{
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.16)),
    repeating-linear-gradient(90deg, #d34831 0 38px, #f7c45b 38px 76px, #88bb5d 76px 114px, #f2eee5 114px 152px);
}
.site-visual.contact::after{
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.16)),
    linear-gradient(135deg, transparent 0 22%, rgba(216,62,42,.26) 22% 24%, transparent 24% 100%),
    repeating-linear-gradient(90deg, rgba(90,135,70,.22) 0 44px, rgba(255,255,255,.18) 44px 88px);
}
.site-visual.booking::after{
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.16)),
    repeating-linear-gradient(0deg, #fff 0 38px, #f0eadf 38px 40px),
    linear-gradient(90deg, rgba(216,62,42,.28), rgba(123,194,79,.28));
}

.eyebrow{
  margin-bottom:12px;
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
}
h1{
  margin:0 0 16px;
  font:400 56px/1.02 var(--hero-serif);
  letter-spacing:-.02em;
}
h2{
  margin:0 0 16px;
  font:400 34px/1.08 var(--hero-serif);
}
h3{
  margin:0 0 12px;
  font:400 24px/1.1 var(--hero-serif);
}
p{margin:0 0 16px;line-height:1.72;color:#40362f}

.hero-copy{display:flex;flex-direction:column;justify-content:center}
.market-scene{
  position:relative;
  min-height:760px;
  padding:0;
  background:
    radial-gradient(circle at top right, rgba(255,240,210,.95), transparent 35%),
    linear-gradient(135deg,#fff8ef 0,#f8eadc 40%,#f0dcc8 100%);
}
.hero-scene-image{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:76% center;
}
.hero-note-card,
.hero-hours-card{
  position:absolute;
  z-index:2;
  max-width:340px;
  padding:22px;
  border-radius:26px;
  background:rgba(255,252,247,.93);
  border:1px solid var(--line);
  box-shadow:0 20px 50px rgba(60,37,22,.14);
}
.hero-note-card{left:8%;bottom:21%}
.hero-hours-card{right:7%;bottom:6%;max-width:300px}
.hero-note-card strong,
.hero-hours-card strong{
  display:block;
  margin-bottom:10px;
  font:400 34px/1.05 var(--hero-serif);
}
.hero-note-card span,
.hero-hours-card span{
  display:block;
  margin-bottom:8px;
  color:#493d35;
  line-height:1.6;
}
.hero-note-card a,
.hero-hours-card a{
  display:inline-block;
  margin-top:10px;
  color:#8a6d44;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.button-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:14px 20px;
  border-radius:999px;
  border:1px solid transparent;
  background:#211a15;
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  cursor:pointer;
}
.btn:hover,
.btn:focus-visible,
.header-btn:hover,
.header-btn:focus-visible{
  transform:translateY(-1px);
  box-shadow:0 16px 34px rgba(60,37,22,.16);
}
.btn.secondary{
  background:#fff;
  color:#241d18;
  border-color:rgba(76,53,38,.14);
}
.btn.warning{background:linear-gradient(180deg,#ffca6b,#ff9715);color:#1f170f}
.btn.alert{background:linear-gradient(180deg,#ff8c7e,#ff5144);color:#1f120f}
.btn.safe{background:linear-gradient(180deg,#9edd79,#6cbf4e);color:#12100d}
.btn.info{background:linear-gradient(180deg,#8ab9ff,#5b91f2);color:#10151f}

.feature-list,
.service-grid,
.story-band,
.three-up,
.contact-lines,
.mission-strip,
.list,
.split-stack,
.portal-actions,
.status-grid,
.tracking-list,
.history-list,
.scheduler-form,
.metrics-grid{
  display:grid;
  gap:16px;
}
.three-up{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:22px}
.story-band{grid-template-columns:1.1fr .9fr;margin-top:22px}
.service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.mission-strip{grid-template-columns:repeat(3,minmax(0,1fr))}
.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr))}

.feature-item{
  display:grid;
  grid-template-columns:56px minmax(0,1fr);
  gap:14px;
  align-items:start;
  padding:14px 0;
  border-bottom:1px solid rgba(76,53,38,.08);
}
.feature-icon{
  width:56px;
  height:56px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:20px;
  font-weight:800;
}
.green{background:#88bb5d}
.orange{background:#ff9d16}
.purple{background:#b087e5}
.red{background:#f06f64}
.blue{background:#6da4ff}

.mini-card,
.service-block,
.contact-lines > div,
.mission-strip > div,
.list-item,
.metric-card,
.panel-block,
.action-card{
  background:rgba(255,255,255,.85);
  border:1px solid rgba(76,53,38,.10);
  border-radius:24px;
  padding:18px;
}
body.site-page .mini-card,
body.site-page .service-block,
body.site-page .contact-lines > div,
body.site-page .mission-strip > div{
  background:rgba(255,252,247,.84);
  box-shadow:0 18px 38px rgba(60,37,22,.08);
}
.mini-card h2{font-size:30px}
.story-card.accent{
  background:linear-gradient(135deg,#eff2d6 0,#c6d991 100%);
}

.field-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.field-grid.single{grid-template-columns:1fr}
label{
  display:grid;
  gap:8px;
  color:#352c26;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
input,select,textarea{
  width:100%;
  border:1px solid rgba(76,53,38,.14);
  border-radius:18px;
  background:#fff;
  color:var(--ink);
  padding:14px 16px;
}
textarea{min-height:130px;resize:vertical}

.stack{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:70;
  display:grid;
  gap:10px;
  justify-items:end;
}
.cta{
  min-width:228px;
  padding:14px 18px;
  border-radius:999px;
  color:#120f0d;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:none;
  border:1px solid rgba(18,15,13,.12);
  box-shadow:0 18px 32px rgba(18,15,13,.18);
}
.cta-dashboard{background:linear-gradient(180deg,#ffc86b,#ff9b16)}
.cta-client{background:linear-gradient(180deg,#ff8f84,#ff5448)}
.cta-back{background:linear-gradient(180deg,#a7df70,#6bbf49)}
.cta:hover,
.cta:focus-visible{
  transform:translateY(-1px);
  box-shadow:0 22px 42px rgba(18,15,13,.22);
}

[data-clock-action],
[data-portal-target]{
  text-transform:none;
  letter-spacing:.04em;
  font-size:14px;
}

.access-gate{
  position:fixed;
  inset:0;
  z-index:200;
  display:grid;
  place-items:center;
  padding:24px;
  background:
    radial-gradient(circle at 16% 16%, rgba(255,255,255,.72), transparent 26%),
    radial-gradient(circle at 84% 20%, rgba(255,157,22,.26), transparent 30%),
    linear-gradient(135deg,#fff8ef,#e7dac9);
}
.access-card{
  width:min(520px,100%);
  padding:34px;
  border-radius:30px;
  background:rgba(255,252,247,.94);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 28px 80px rgba(60,37,22,.2);
}
.access-card h1{
  font-size:42px;
}
.access-card form{
  display:grid;
  gap:14px;
}
.access-error{
  display:none;
  margin-top:10px;
  color:#a72f22;
  font-weight:800;
}
.access-error.show{display:block}

.dashboard-shell{
  width:min(1380px,100%);
  margin:0 auto;
}
.menu-backdrop{
  position:fixed;
  inset:0;
  z-index:79;
  background:rgba(15,10,7,.34);
  opacity:0;
  visibility:hidden;
  transition:.2s ease;
}
.menu-backdrop.open{opacity:1;visibility:visible}
.drawer-panel{
  position:fixed;
  top:88px;
  left:22px;
  z-index:80;
  width:min(360px,calc(100vw - 44px));
  transform:translateY(-12px);
  opacity:0;
  visibility:hidden;
  transition:.2s ease;
}
.drawer-panel.open{
  transform:translateY(0);
  opacity:1;
  visibility:visible;
}
.drawer-links{
  display:grid;
  gap:10px;
}
.drawer-link{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(76,53,38,.10);
  font-weight:800;
}
.drawer-link small{
  color:var(--muted);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.status-banner{
  display:none;
  margin-top:14px;
  padding:14px 16px;
  border-radius:18px;
  background:#fff8e4;
  border:1px solid rgba(255,163,0,.18);
  font-weight:800;
}
.status-banner.show{display:block}
.status-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:20px}
.status-chip{
  padding:18px;
  border-radius:24px;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(76,53,38,.10);
}
.status-chip strong{
  display:block;
  margin-bottom:8px;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.timer{
  font:400 40px/1 var(--hero-serif);
}
.assignment-card{
  margin-top:22px;
  padding:20px;
  border-radius:26px;
  background:linear-gradient(135deg,#f2efdb 0,#d7e4b4 100%);
  border:1px solid rgba(76,53,38,.10);
}

.schedule{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.schedule-row{
  display:grid;
  grid-template-columns:minmax(120px,.9fr) repeat(var(--schedule-days,7),minmax(64px,1fr));
  gap:10px;
  align-items:start;
}
.person,.cell{
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(76,53,38,.10);
}
.person strong,.cell strong{display:block}
.hero-note{
  margin-top:8px;
  color:var(--muted);
  font-size:12px;
  line-height:1.5;
}
.pill{
  display:block;
  width:100%;
  padding:10px 8px;
  border-radius:999px;
  text-align:center;
  color:#16110d;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.06),0 8px 18px rgba(0,0,0,.08);
}
.off{background:var(--off)}
.on{background:var(--on)}
.call{background:var(--call)}

.link-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}
.record-link{
  color:#1f1a15;
  font-weight:800;
  text-decoration:underline;
  text-underline-offset:3px;
}

.map-shell{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(76,53,38,.10);
  min-height:480px;
  background:#dce7f4;
}
.map-shell iframe{
  width:100%;
  height:480px;
  border:0;
  filter:saturate(.9) contrast(1.02);
}
.map-pin{
  position:absolute;
  padding:10px 12px;
  border-radius:18px;
  background:rgba(255,252,247,.95);
  border:1px solid rgba(76,53,38,.12);
  box-shadow:0 16px 30px rgba(60,37,22,.15);
  font-size:12px;
  font-weight:800;
}
.map-pin::after{
  content:"";
  position:absolute;
  left:16px;
  bottom:-10px;
  width:16px;
  height:16px;
  background:inherit;
  border-right:1px solid rgba(76,53,38,.12);
  border-bottom:1px solid rgba(76,53,38,.12);
  transform:rotate(45deg);
}
.pin-a{top:18%;left:18%}
.pin-b{top:42%;right:18%}
.pin-c{bottom:16%;left:32%}

.portal-actions{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.action-card{
  display:grid;
  gap:12px;
  align-content:start;
}
.hidden-panel{display:none}
.hidden-panel.active{display:block}

.print-page{
  background:#fff;
  color:#111;
}
.print-shell{
  width:min(920px,calc(100% - 48px));
  margin:24px auto 120px;
  padding:36px;
  border-radius:20px;
  background:#fff;
  border:1px solid #ddd;
  box-shadow:none;
}
.print-head,
.invoice-line,
.summary-line{
  display:flex;
  justify-content:space-between;
  gap:16px;
}
.print-table{
  width:100%;
  border-collapse:collapse;
  margin:26px 0;
}
.print-table th,
.print-table td{
  border-bottom:1px solid #ddd;
  padding:12px 8px;
  text-align:left;
}
.summary{
  margin-top:24px;
  display:grid;
  gap:10px;
}

.utility-note{
  color:var(--muted);
  font-size:13px;
}
.success-note{
  margin-top:14px;
  padding:14px 16px;
  border-radius:18px;
  background:#eff8e9;
  border:1px solid rgba(108,191,78,.22);
  color:#234116;
  font-weight:800;
  display:none;
}
.success-note.show{display:block}

@media (max-width:1180px){
  .hero-grid,
  .portal-grid,
  .booking-grid,
  .three-up,
  .story-band,
  .service-grid,
  .mission-strip,
  .portal-actions,
  .metrics-grid,
  .status-grid{
    grid-template-columns:1fr;
  }
  .schedule-row{
    grid-template-columns:1fr;
  }
  .hero-note-card,
  .hero-hours-card{
    position:relative;
    left:auto;
    right:auto;
    bottom:auto;
    max-width:none;
    margin:18px;
  }
  .market-scene{min-height:900px}
  h1{font-size:44px}
}

@media (max-width:760px){
  .shell{padding:14px 14px 150px}
  .site-header,
  .dashboard-header{
    border-radius:28px;
    align-items:flex-start;
  }
  .site-nav,
  .dashboard-actions,
  .button-row{
    width:100%;
  }
  .field-grid{grid-template-columns:1fr}
  .stack{right:14px;bottom:14px}
  .cta{min-width:204px}
  .drawer-panel{left:14px;width:min(340px,calc(100vw - 28px))}
}
