/* GSSM prototype theme, Stoa. Palette from scgssm.org Drupal theme.
   Display: Bricolage Grotesque · Body: Public Sans (both self-hosted, OFL). */

@font-face{
  font-family:"Bricolage Grotesque";
  src:url("/stateofsouthcarolinasfaaprocurement/assets/fonts/BricolageGrotesque-var.woff2") format("woff2");
  font-weight:200 800;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Public Sans";
  src:url("/stateofsouthcarolinasfaaprocurement/assets/fonts/PublicSans-var.woff2") format("woff2");
  font-weight:100 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Public Sans";
  src:url("/stateofsouthcarolinasfaaprocurement/assets/fonts/PublicSans-italic-var.woff2") format("woff2");
  font-weight:100 900;font-style:italic;font-display:swap;
}

:root{
  --navy:#002d49;
  --navy-deep:#001d30;
  --navy-2:#003f6a;
  --blue:#0071bc;
  --sky:#1baae4;
  --sky-pale:#ebf9ff;
  --rasp:#d60958;
  --rasp-ink:#b80048;   /* AA on paper for small text */
  --rasp-bright:#ff4d8d;/* on navy rooms */
  --paper:#f8fbfd;
  --card:#ffffff;
  --ink:#10212e;
  --ink-soft:#3d5160;
  --line:#cfdde6;
  --grid:rgba(0,45,73,.07);
  --display:"Bricolage Grotesque","Avenir Next",system-ui,sans-serif;
  --body:"Public Sans","Helvetica Neue",Arial,sans-serif;
  --wrap:72rem;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font:400 1.0625rem/1.65 var(--body);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}

h1,h2,h3{font-family:var(--display);color:var(--navy);line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2rem,5.4vw,3.4rem);font-weight:800;margin:0 0 .6rem}
h2{font-size:clamp(1.45rem,3vw,2.05rem);font-weight:800;margin:0 0 .75rem}
h3{font-size:1.15rem;font-weight:700;margin:0 0 .4rem}
p{margin:.45rem 0 1rem}
.lead{font-size:1.2rem;color:var(--ink-soft);max-width:56ch}

a{color:var(--blue);text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{color:var(--rasp-ink)}
:focus-visible{outline:3px solid var(--rasp);outline-offset:2px;border-radius:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.skip{position:absolute;left:-999px;top:0;z-index:60;background:var(--card);color:var(--navy);
  padding:.7rem 1.1rem;font-weight:700;border:2px solid var(--navy);border-radius:0 0 6px 0}
.skip:focus{left:0}

/* ---------- chrome ---------- */
.proto-banner{background:var(--navy-deep);color:#cfe6f5;font-size:.85rem;padding:.45rem 0}
.proto-banner .wrap{display:flex;gap:.6rem;align-items:baseline;flex-wrap:wrap}
.proto-banner a{color:#c0e3fa}
.proto-banner strong{color:#fff}

.site-head{background:var(--card);border-bottom:4px solid var(--navy);position:relative}
.head-row{display:flex;align-items:center;gap:1rem;padding-block:.85rem;flex-wrap:wrap}
.lockup{display:flex;gap:.7rem;align-items:center;text-decoration:none;color:var(--navy);margin-right:auto}
.lockup .mark{flex:none;width:46px;height:46px;display:grid;place-items:center;
  background:var(--navy);border-radius:8px}
.lockup .mark svg{width:30px;height:30px}
.lockup-name{display:block;font-family:var(--display);font-weight:800;font-size:1.02rem;line-height:1.15}
.lockup-sub{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}

.head-search{display:flex;flex:1 1 14rem;max-width:24rem;border:2px solid var(--navy);border-radius:8px;overflow:hidden;background:#fff}
.head-search input{flex:1;min-width:0;border:0;padding:.55rem .8rem;font:inherit;font-size:.95rem;color:var(--ink)}
.head-search input:focus{outline:none}
.head-search:focus-within{outline:3px solid var(--rasp);outline-offset:2px}
.head-search button{border:0;background:var(--navy);color:#fff;font:600 .9rem var(--body);padding:.55rem .9rem;cursor:pointer;min-height:24px}
.head-search button:hover{background:var(--rasp-ink)}

.menu-btn{display:none;border:2px solid var(--navy);background:#fff;color:var(--navy);
  font:700 .95rem var(--body);padding:.5rem .9rem;border-radius:8px;cursor:pointer;min-height:44px}
.menu-btn[aria-expanded="true"]{background:var(--navy);color:#fff}

.primary-nav{background:var(--card)}
.primary-nav ul{list-style:none;margin:0;padding-block:0;display:flex;flex-wrap:wrap;gap:.1rem}
.primary-nav a{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem .85rem;min-height:44px;
  color:var(--navy);text-decoration:none;font-weight:600;font-size:.95rem;border-top:3px solid transparent}
.primary-nav a::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--line);flex:none}
.primary-nav a:hover{border-top-color:var(--sky)}
.primary-nav a:hover::before{background:var(--sky)}
.primary-nav a[aria-current="page"]{border-top-color:var(--rasp);color:var(--navy)}
.primary-nav a[aria-current="page"]::before{background:var(--rasp)}
.primary-nav .nav-demo a{color:var(--rasp-ink)}
.primary-nav .nav-demo a::before{background:var(--rasp)}

/* ---------- graph-grid motif ---------- */
.grid-bg{
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),
                   linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:28px 28px;
}
.tick-rule{border:0;height:10px;margin:0;background:
  repeating-linear-gradient(90deg,var(--line) 0 1px,transparent 1px 28px) bottom/100% 6px no-repeat,
  linear-gradient(var(--line),var(--line)) bottom/100% 1px no-repeat}

/* ---------- hero ---------- */
.hero{position:relative;color:#fff;background:var(--navy-deep)}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(0,29,48,.93) 0%,rgba(0,29,48,.78) 45%,rgba(0,45,73,.45) 100%)}
.hero-inner{position:relative;padding-block:clamp(3rem,8vw,5.5rem)}
.hero h1{color:#fff;max-width:21ch}
.hero .lead{color:#d9ecf7}
.eyebrow{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--rasp-ink);margin:0 0 .8rem}
.hero .eyebrow{color:#7fd2f5}

.audience{margin-top:2rem;border-top:1px solid rgba(255,255,255,.25);padding-top:1.2rem}
.audience p{margin:0 0 .6rem;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#9fc6dd}
.audience ul{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;margin:0;padding:0}
.audience a{display:inline-flex;align-items:center;min-height:44px;padding:.45rem 1rem;border:1.5px solid rgba(255,255,255,.55);
  border-radius:999px;color:#fff;text-decoration:none;font-weight:600;font-size:.95rem}
.audience a:hover,.audience a:focus-visible{background:var(--rasp);border-color:var(--rasp);color:#fff}

/* ---------- notebook-entry spine ---------- */
.entries{list-style:none;margin:0;padding:0;position:relative}
.entry{position:relative;padding:1.4rem 0 1.4rem 3.4rem;border-bottom:1px solid var(--line)}
.entry:last-child{border-bottom:0}
.entry::before{content:"";position:absolute;left:13px;top:0;bottom:0;width:2px;background:var(--line)}
.entry:first-child::before{top:1.9rem}
.entry:last-child::before{bottom:auto;height:1.9rem}
.entry::after{content:"";position:absolute;left:7px;top:1.62rem;width:14px;height:14px;border-radius:50%;
  background:var(--rasp);border:3px solid var(--paper);box-shadow:0 0 0 2px var(--rasp)}
.entry .entry-no{font-family:var(--display);font-weight:800;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--rasp-ink)}
.entry h3{font-size:1.3rem;margin:.15rem 0 .3rem}
.entry h3 a{color:var(--navy);text-decoration:none}
.entry h3 a:hover{color:var(--rasp-ink);text-decoration:underline}
.entry p{margin:0;max-width:62ch;color:var(--ink-soft)}
.entry .entry-meta{font-size:.85rem;color:var(--ink-soft);margin-top:.3rem;display:block}

/* ---------- specimen slides (photo system) ---------- */
.slide-mount{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.65rem;
  box-shadow:0 2px 10px rgba(0,45,73,.08)}
.slide-mount img{border:2px solid var(--navy);border-radius:6px;width:100%;object-fit:cover}
.slide-label{display:flex;gap:.6rem;align-items:baseline;padding:.55rem .3rem .1rem;font-size:.85rem;color:var(--ink-soft)}
.slide-label .tag{flex:none;font-family:var(--display);font-weight:800;font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:#fff;background:var(--rasp);padding:.15rem .5rem;border-radius:4px}

/* ---------- sections ---------- */
.section{padding-block:clamp(2.4rem,6vw,4rem)}
.section-alt{background:#fff;border-block:1px solid var(--line)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem}
.section-head p{margin:0;color:var(--ink-soft)}
.more-link{font-weight:700;white-space:nowrap}

.lab-room{background:var(--navy-deep);color:#d9ecf7}
.lab-room h2,.lab-room h3{color:#fff}
.lab-room .eyebrow{color:var(--rasp-bright)}
.lab-room a{color:#c0e3fa}
.lab-room .grid-bg{background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px)}

.cols-2{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(19rem,1fr));align-items:start}
.cols-3{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr))}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.7rem 1.4rem;
  border-radius:8px;font:700 1rem var(--body);text-decoration:none;cursor:pointer;border:2px solid transparent}
.btn-rasp,.lab-room a.btn-rasp{background:var(--rasp);color:#fff}
.btn-rasp:hover,.lab-room a.btn-rasp:hover{background:var(--rasp-ink);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);color:#fff}
.btn-ghost{border-color:var(--navy);color:var(--navy);background:transparent}
.btn-ghost:hover{background:var(--navy);color:#fff}
.lab-room .btn-ghost{border-color:#c0e3fa;color:#d9ecf7}
.lab-room .btn-ghost:hover{background:#fff;border-color:#fff;color:var(--navy)}

.node-list{list-style:none;margin:.6rem 0 1rem;padding:0}
.node-list li{position:relative;padding:.28rem 0 .28rem 1.5rem}
.node-list li::before{content:"";position:absolute;left:.2rem;top:.85em;width:9px;height:9px;border-radius:50%;
  background:var(--rasp)}
.lab-room .node-list li::before{background:var(--rasp-bright)}

.note{font-size:.85rem;color:var(--ink-soft);border-left:3px solid var(--sky);background:var(--sky-pale);
  padding:.55rem .8rem;border-radius:0 6px 6px 0}
.lab-room .note{background:rgba(27,170,228,.12);color:#cfe6f5}

.chip{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.18rem .55rem;border-radius:4px;background:var(--sky-pale);color:var(--navy-2)}
.chip-sample{background:#fdeef4;color:var(--rasp-ink)}

/* ---------- event strip + calendar ---------- */
.event-strip{list-style:none;margin:0;padding:0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr))}
.event-card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:1rem;display:flex;gap:.9rem}
.date-tile{flex:none;width:3.4rem;text-align:center;border:2px solid var(--navy);border-radius:8px;overflow:hidden;align-self:flex-start}
.date-tile .m{display:block;background:var(--navy);color:#fff;font:700 .68rem/1.6 var(--body);letter-spacing:.12em;text-transform:uppercase}
.date-tile .d{display:block;font-family:var(--display);font-weight:800;font-size:1.45rem;color:var(--navy);padding:.1rem 0}
.event-card h3{font-size:1rem;margin:0 0 .2rem}
.event-card p{margin:0;font-size:.88rem;color:var(--ink-soft)}

.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.4rem}
.filter-bar button{border:1.5px solid var(--navy);background:#fff;color:var(--navy);font:600 .9rem var(--body);
  padding:.45rem .95rem;border-radius:999px;cursor:pointer;min-height:44px}
.filter-bar button[aria-pressed="true"]{background:var(--navy);color:#fff}
.filter-bar button:hover{border-color:var(--rasp);color:var(--rasp-ink)}
.filter-bar button[aria-pressed="true"]:hover{background:var(--rasp-ink);border-color:var(--rasp-ink);color:#fff}

.cal-head{display:flex;align-items:center;gap:1rem;justify-content:space-between;flex-wrap:wrap;margin-bottom:1rem}
.cal-head h2{margin:0}
.cal-nav{display:flex;gap:.5rem}
.cal-nav button{border:2px solid var(--navy);background:#fff;color:var(--navy);border-radius:8px;
  font:700 1rem var(--body);min-width:44px;min-height:44px;cursor:pointer}
.cal-nav button:hover{background:var(--navy);color:#fff}
.cal-scroll,.table-scroll{overflow-x:auto}
table.cal{width:100%;min-width:34rem;border-collapse:collapse;background:#fff;border:1px solid var(--line)}
table.cal th{background:var(--navy);color:#fff;font:700 .78rem var(--body);letter-spacing:.1em;text-transform:uppercase;padding:.5rem .4rem}
table.cal td{border:1px solid var(--line);vertical-align:top;min-height:5rem;height:5.6rem;padding:.35rem;width:14.28%}
table.cal td .dnum{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--ink-soft)}
table.cal td.other{background:var(--paper)}
table.cal td.today .dnum{background:var(--rasp);color:#fff;border-radius:50%;display:inline-grid;place-items:center;width:1.7rem;height:1.7rem}
.cal-evt{display:block;font-size:.74rem;line-height:1.25;margin-top:.25rem;padding:.2rem .35rem;border-radius:4px;
  background:var(--sky-pale);color:var(--navy-2);text-decoration:none;border-left:3px solid var(--sky)}
.cal-evt.cat-residential{border-left-color:var(--rasp);background:#fdeef4;color:var(--rasp-ink)}
.cal-evt.cat-admissions{border-left-color:var(--navy);background:#e8eef3;color:var(--navy)}
.cal-evt.cat-goscitech{border-left-color:#e09600;background:#fdf3dd;color:#6b4a00}
.cal-evt.cat-outreach{border-left-color:#4c8a3f;background:#ecf5e9;color:#1e4d2b}
.legend{display:flex;flex-wrap:wrap;gap:1rem;font-size:.85rem;margin-top:.8rem;color:var(--ink-soft)}
.legend span{display:inline-flex;align-items:center;gap:.4rem}
.legend i{width:12px;height:12px;border-radius:3px;display:inline-block}

/* ---------- forms ---------- */
.form-grid{display:grid;gap:1rem;max-width:38rem}
label{font-weight:700;font-size:.95rem;color:var(--navy)}
input[type=text],input[type=email],input[type=search],select,textarea{
  width:100%;font:inherit;padding:.6rem .7rem;border:2px solid var(--navy-2);border-radius:8px;background:#fff;color:var(--ink)}
textarea{min-height:7rem;resize:vertical}
fieldset{border:1px solid var(--line);border-radius:10px;padding:1rem}
legend{font-weight:700;color:var(--navy);padding-inline:.4rem}

/* ---------- footer ---------- */
.site-foot{background:var(--navy-deep);color:#cfe0ec;margin-top:3rem}
.site-foot .tick-top{height:8px;background:
  repeating-linear-gradient(90deg,var(--rasp) 0 28px,var(--sky) 28px 56px,#fff0 56px 84px) top/100% 4px no-repeat,var(--navy)}
.foot-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));padding-block:2.4rem}
.site-foot h2{color:#fff;font-size:1rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.7rem}
.site-foot ul{list-style:none;margin:0;padding:0}
.site-foot li{padding:.22rem 0}
.site-foot a{color:#c0e3fa}
.site-foot a:hover{color:#fff}
.foot-legal{border-top:1px solid rgba(255,255,255,.18);padding-block:1.1rem;font-size:.85rem;color:#9db8c9}
address{font-style:normal;line-height:1.7}

/* ---------- search page ---------- */
.search-hero{padding-block:2.2rem 1.4rem}
.search-big{display:flex;max-width:38rem;border:3px solid var(--navy);border-radius:10px;overflow:hidden;background:#fff}
.search-big input{flex:1;min-width:0;border:0;font:inherit;font-size:1.1rem;padding:.8rem 1rem}
.search-big input:focus{outline:none}
.search-big:focus-within{outline:3px solid var(--rasp);outline-offset:2px}
.search-big button{border:0;background:var(--navy);color:#fff;font:700 1rem var(--body);padding:0 1.3rem;cursor:pointer}
.search-big button:hover{background:var(--rasp-ink)}
.result{padding:1rem 0;border-bottom:1px solid var(--line)}
.result h3{margin:0 0 .2rem}
.result h3 a{text-decoration:none}
.result h3 a:hover{text-decoration:underline}
.result .crumb{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--rasp-ink);font-weight:700}
.result p{margin:.25rem 0 0;color:var(--ink-soft);font-size:.95rem}
.result mark{background:#ffe2ed;color:inherit;border-radius:2px;padding:0 .1em}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--ink-soft)}
.empty-state svg{margin-inline:auto;display:block;margin-bottom:1rem}

/* ---------- CMS demo ---------- */
.cms-shell{display:grid;gap:1.4rem;grid-template-columns:minmax(0,1fr) 20rem;align-items:start}
.cms-stage{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cms-stage-head{display:flex;align-items:center;gap:.7rem;background:var(--paper);border-bottom:1px solid var(--line);
  padding:.6rem .9rem;font-size:.85rem;color:var(--ink-soft);flex-wrap:wrap}
.status-pill{font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .6rem;border-radius:999px}
.status-draft{background:#fdf3dd;color:#6b4a00}
.status-review{background:#e8eef3;color:var(--navy)}
.status-published{background:#ecf5e9;color:#1e4d2b}
.cms-canvas{padding:1.2rem;display:grid;gap:.7rem}
.block{position:relative;border:2px dashed transparent;border-radius:8px;padding:.7rem .8rem .7rem 2.6rem}
.block:hover,.block:focus-within{border-color:var(--sky)}
.block.dragging{opacity:.45;border-color:var(--rasp)}
.block.dropover{border-color:var(--rasp);background:#fdeef4}
.block-tools{position:absolute;left:.35rem;top:.55rem;display:grid;gap:.2rem}
.block-tools button{width:28px;height:28px;border:1px solid var(--line);background:#fff;border-radius:6px;cursor:pointer;
  font-size:.8rem;line-height:1;color:var(--navy);display:grid;place-items:center;padding:0}
.block-tools button:hover{border-color:var(--rasp);color:var(--rasp-ink)}
.block [contenteditable]{outline-offset:3px;border-radius:4px}
.block [contenteditable]:focus-visible{outline:3px solid var(--rasp)}
.block h3{font-size:1.45rem}
.block .b-callout{background:var(--sky-pale);border-left:4px solid var(--sky);padding:.7rem .9rem;border-radius:0 8px 8px 0}
.cms-panel{background:var(--navy-deep);color:#d9ecf7;border-radius:12px;padding:1.2rem;position:sticky;top:1rem}
.cms-panel h2{color:#fff;font-size:1.1rem;margin-top:0}
.cms-panel h3{color:#c0e3fa;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin:1.1rem 0 .45rem}
.cms-panel .btn{width:100%;margin-top:.5rem}
.cms-panel .btn-ghost{border-color:#c0e3fa;color:#d9ecf7}
.cms-panel .btn-ghost:hover{background:#fff;border-color:#fff;color:var(--navy)}
.cms-panel .seg{display:flex;border:1.5px solid #4a768e;border-radius:8px;overflow:hidden}
.cms-panel .seg button{flex:1;border:0;background:transparent;color:#d9ecf7;font:600 .9rem var(--body);padding:.5rem;cursor:pointer;min-height:44px}
.cms-panel .seg button[aria-pressed="true"]{background:var(--rasp);color:#fff}
.cms-log{list-style:none;margin:.4rem 0 0;padding:0;font-size:.82rem;max-height:11rem;overflow:auto}
.cms-log li{padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.12)}
.cms-log time{color:#c0e3fa;margin-right:.4rem}

/* ---------- tables ---------- */
table.data{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);font-size:.95rem}
table.data th{background:var(--navy);color:#fff;text-align:left;padding:.6rem .8rem;font-weight:700}
table.data td{border-top:1px solid var(--line);padding:.6rem .8rem;vertical-align:top}
table.data tr:nth-child(even) td{background:var(--paper)}

/* ---------- responsive ---------- */
@media (max-width:56rem){
  .cms-shell{grid-template-columns:1fr}
  .cms-panel{position:static}
}
@media (max-width:47rem){
  .menu-btn{display:inline-flex;align-items:center}
  .head-search{order:3;flex-basis:100%;max-width:none}
  .primary-nav{display:none;border-top:1px solid var(--line)}
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;padding-block:.4rem}
  .primary-nav a{border-top:0;border-left:3px solid transparent;width:100%}
  .primary-nav a[aria-current="page"]{border-left-color:var(--rasp)}
  table.cal{font-size:.8rem}
  table.cal td{height:4.4rem;padding:.2rem}
  .cal-evt{font-size:.62rem;padding:.12rem .25rem}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition:none !important;animation:none !important}
}
