/* ═══════════════════════════════════════════════
   GRAFTAP.CSS — Shared styles for all pages
   graftap.co.uk
════════════════════════════════════════════════ */

:root{
  --ink:#0A1520;
  --navy:#0f3358;
  --blue:#1a5fa8;
  --sky:#3b9edd;
  --ice:#d4eaf9;
  --white:#f5f9fc;
  --amber:#f5a623;
  --red:#e8384f;
  --green:#1db954;
  --border:rgba(255,255,255,.08);
  --muted:rgba(255,255,255,.45);
  --hint:rgba(255,255,255,.25);
}

/* ── RESET & BASE ── */
*{box-sizing:border-box;margin:0;padding:0}
html{font-family:'Barlow',sans-serif;background:var(--ink);color:var(--white);scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.4;pointer-events:none;z-index:0}

.banner{background:var(--amber);color:var(--ink);text-align:center;padding:10px 20px;font-size:13px;font-weight:700;letter-spacing:.5px;position:sticky;top:0;z-index:300}
.banner{font-size:12px;padding:8px 16px;line-height:1.4}
.banner{font-size:11px;padding:7px 12px}
nav{position:sticky;top:40px;left:0;right:0;z-index:200;padding:0 5vw;display:flex;align-items:center;justify-content:space-between;height:60px;background:rgba(10,21,32,.9);backdrop-filter:blur(16px);border-bottom:0.5px solid var(--border)}
nav{top:52px;height:54px;padding:0 4vw}
nav{top:46px;height:52px;padding:0 4vw}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-name{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;letter-spacing:1px;color:var(--white);text-transform:uppercase}
.nav-logo-name{font-size:18px}
.nav-logo-name{font-size:17px}
.nav-logo-name{font-size:15px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links{display:none}
.nav-links{gap:16px}
.nav-link{font-size:14px;font-weight:500;color:var(--muted);text-decoration:none;transition:color .2s}
.nav-link{font-size:13px}
.nav-link:hover{color:var(--white)}
.nav-cta{background:var(--amber);color:var(--ink);border:none;border-radius:6px;padding:9px 20px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Barlow',sans-serif;letter-spacing:.3px;transition:opacity .2s}
.nav-cta{padding:8px 14px;font-size:13px}
.nav-cta:hover{opacity:.88}
footer{padding:40px 5vw;border-top:0.5px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:gap;gap:16px}
footer{flex-direction:column;align-items:flex-start;gap:16px;padding:32px 5vw}
footer{padding:28px 5vw}
.footer-logo-name{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}
.footer-links{gap:16px}
.footer-links{flex-wrap:wrap;gap:12px}
.footer-link{font-size:13px;color:var(--hint);text-decoration:none;transition:color .2s}
.footer-link:hover{color:var(--muted)}
.footer-copy{font-size:12px;color:var(--hint)}
.footer-copy{font-size:11px}
.btn-amber{background:var(--amber);color:var(--ink);border:none;border-radius:8px;padding:15px 32px;font-size:16px;font-weight:700;cursor:pointer;font-family:'Barlow',sans-serif;letter-spacing:.3px;transition:all .2s}
.btn-amber{width:100%}
.btn-amber:hover{background:#f7b440;transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--white);border-radius:8px;padding:15px 32px;font-size:16px;font-weight:600;cursor:pointer;font-family:'Barlow',sans-serif;transition:all .2s}
.btn-ghost{padding:13px 24px;font-size:15px;width:100%}
.btn-ghost{padding:14px 20px;font-size:15px}
.btn-ghost:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.05)}
.soon-badge{display:inline-block;background:rgba(245,166,35,.15);border:0.5px solid rgba(245,166,35,.3);color:#f5a623;font-size:9px;font-family:"DM Mono",monospace;letter-spacing:.06em;padding:2px 7px;border-radius:4px;margin-left:6px;vertical-align:middle;font-weight:600}

/* ── CHATBOT ── */
.gc-btn{position:fixed;bottom:24px;right:24px;z-index:900;width:52px;height:52px;background:#1a5fa8;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.35);transition:all .2s}
.gc-btn:hover{background:#1e6dbf;transform:scale(1.05)}
.gc-btn .gc-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:rgba(26,95,168,.4);animation:gc-pulse 2s infinite}
@keyframes gc-pulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.6);opacity:0}}
.gc-panel{position:fixed;bottom:88px;right:24px;z-index:900;width:340px;max-width:calc(100vw - 32px);background:#0d1d2e;border:0.5px solid rgba(59,158,221,.25);border-radius:16px;box-shadow:0 12px 48px rgba(0,0,0,.5);display:none;flex-direction:column;overflow:hidden;font-family:'Barlow',system-ui,sans-serif}
.gc-panel.open{display:flex}
.gc-header{background:#1a4d7c;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.gc-header-left{display:flex;align-items:center;gap:10px}
.gc-avatar{width:32px;height:32px;background:#0f3358;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gc-name{font-size:14px;font-weight:700;color:#fff}
.gc-status{font-size:11px;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:4px}
.gc-status::before{content:'';width:6px;height:6px;background:#25d366;border-radius:50%;display:inline-block}
.gc-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:18px;cursor:pointer;line-height:1;padding:2px;transition:color .2s}
.gc-close:hover{color:#fff}
.gc-messages{flex:1;padding:14px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;min-height:260px;max-height:340px;scroll-behavior:smooth}
.gc-messages::-webkit-scrollbar{width:3px}
.gc-messages::-webkit-scrollbar-track{background:transparent}
.gc-messages::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.gc-msg{max-width:88%;padding:8px 11px;border-radius:10px;font-size:13px;line-height:1.55;animation:gc-fade .25s ease}
@keyframes gc-fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.gc-bot-msg{background:#1f2c34;color:#e9edef;align-self:flex-start;border-top-left-radius:2px}
.gc-bot-msg a{color:#3b9edd;text-decoration:none}
.gc-bot-msg a:hover{text-decoration:underline}
.gc-usr-msg{background:#1a5fa8;color:#fff;align-self:flex-end;border-top-right-radius:2px}
.gc-typing{background:#1f2c34;align-self:flex-start;padding:10px 12px;border-radius:10px;border-top-left-radius:2px;display:none}
.gc-typing.show{display:block}
.gc-td{width:5px;height:5px;background:#8696a0;border-radius:50%;display:inline-block;animation:gc-tb .9s infinite}
.gc-td:nth-child(2){animation-delay:.15s}.gc-td:nth-child(3){animation-delay:.3s}
@keyframes gc-tb{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}
.gc-suggestions{display:flex;gap:6px;flex-wrap:wrap;padding:0 12px 10px;flex-shrink:0}
.gc-chip{background:rgba(59,158,221,.1);border:0.5px solid rgba(59,158,221,.25);border-radius:14px;padding:5px 11px;font-size:12px;color:#3b9edd;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:'Barlow',system-ui,sans-serif}
.gc-chip:hover{background:rgba(59,158,221,.2);border-color:rgba(59,158,221,.5)}
.gc-input-row{display:flex;gap:8px;padding:10px 12px;border-top:0.5px solid rgba(255,255,255,.06);flex-shrink:0}
.gc-input{flex:1;background:rgba(255,255,255,.07);border:0.5px solid rgba(255,255,255,.12);border-radius:20px;padding:9px 14px;color:#fff;font-size:13px;font-family:'Barlow',system-ui,sans-serif;outline:none;transition:border-color .2s}
.gc-input:focus{border-color:rgba(59,158,221,.5)}
.gc-input::placeholder{color:rgba(255,255,255,.3)}
.gc-send{background:#1a5fa8;border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}
.gc-send:hover{background:#1e6dbf}
.gc-send:disabled{opacity:.4;cursor:not-allowed}
.gc-branding{text-align:center;font-size:10px;color:rgba(255,255,255,.2);padding:6px 0;font-family:monospace;letter-spacing:.04em;flex-shrink:0}
@media(max-width:480px){.gc-panel{right:12px;bottom:80px;width:calc(100vw - 24px)}}

/* ── FACT POPUP ── */
.fact-popup{position:fixed;bottom:24px;right:24px;z-index:400;max-width:300px;background:#0d1d2e;border:0.5px solid rgba(59,158,221,.3);border-radius:12px;padding:18px 20px;box-shadow:0 8px 32px rgba(0,0,0,.4);transform:translateY(120px);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);pointer-events:none}
.fact-popup.show{transform:translateY(0);opacity:1;pointer-events:all}
.fact-popup-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.fact-popup-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--sky)}
.fact-popup-close{background:none;border:none;color:var(--hint);font-size:16px;cursor:pointer;padding:0;line-height:1;transition:color .2s}
.fact-popup-close:hover{color:var(--white)}
.fact-popup-icon{font-size:24px;margin-bottom:8px}
.fact-popup-text{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.fact-popup-next{background:none;border:0.5px solid rgba(255,255,255,.1);border-radius:6px;padding:6px 12px;font-size:12px;color:var(--muted);cursor:pointer;font-family:'Barlow',sans-serif;transition:all .2s}
.fact-popup-next:hover{border-color:var(--sky);color:var(--white)}
@media(max-width:480px){
  .fact-popup{bottom:16px;right:12px;left:12px;max-width:100%}
}



@media(max-width:600px){.nav-links{display:none}}
@media(max-width:480px){nav{top:44px}.banner{font-size:11px;padding:7px 10px}footer{flex-direction:column;align-items:flex-start}}




/* ── COMPANY REGISTRATION BADGE ── */
.footer-reg{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);border:0.5px solid rgba(255,255,255,.08);border-radius:6px;padding:4px 10px;margin-top:6px}
.footer-reg svg{flex-shrink:0}
.footer-reg span{font-size:10px;color:rgba(255,255,255,.3);font-family:"DM Mono",monospace;letter-spacing:.04em}

/* ── AREA SELECTOR ── */
.as-wrap{
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:8px 10px;
  cursor:text;
  transition:border-color .2s,box-shadow .2s;
  position:relative;
  min-height:48px;
}
.as-wrap:hover{border-color:rgba(255,255,255,.2)}
.as-wrap.focused{
  border-color:var(--sky);
  box-shadow:0 0 0 3px rgba(59,158,221,.12);
}
.as-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.as-tag{
  display:inline-flex;
  align-items:center;
  gap:5px;
  background:linear-gradient(135deg,rgba(26,95,168,.5),rgba(26,95,168,.3));
  border:1px solid rgba(59,158,221,.4);
  border-radius:20px;
  padding:4px 6px 4px 12px;
  font-size:13px;
  font-weight:500;
  color:#e8f4ff;
  white-space:nowrap;
  animation:as-pop .15s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter:blur(4px);
}
@keyframes as-pop{
  from{opacity:0;transform:scale(.7) translateY(4px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.as-tag-text{
  font-family:"Barlow",sans-serif;
  letter-spacing:.01em;
}
.as-tag-x{
  background:rgba(255,255,255,.12);
  border:none;
  border-radius:50%;
  width:18px;
  height:18px;
  min-width:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:9px;
  color:rgba(255,255,255,.6);
  padding:0;
  transition:background .15s,color .15s;
  line-height:1;
}
.as-tag-x:hover{
  background:rgba(229,57,53,.6);
  color:#fff;
}
.as-input{
  background:none;
  border:none;
  outline:none;
  color:var(--white);
  font-size:14px;
  font-family:"Barlow",sans-serif;
  min-width:140px;
  flex:1;
  padding:5px 2px;
  caret-color:var(--sky);
  height:30px;
}
.as-input::placeholder{color:rgba(255,255,255,.2);font-style:italic}
.as-input:disabled{cursor:not-allowed;opacity:.3}
.as-dropdown{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  background:#0d1d2e;
  border:1px solid rgba(59,158,221,.25);
  border-radius:12px;
  overflow:hidden;
  z-index:500;
  display:none;
  box-shadow:0 16px 48px rgba(0,0,0,.6),0 0 0 0.5px rgba(59,158,221,.1);
  animation:as-drop .12s ease;
}
@keyframes as-drop{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
.as-dropdown.open{display:block}
.as-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:11px 16px;
  cursor:pointer;
  transition:background .1s;
  border-bottom:0.5px solid rgba(255,255,255,.05);
  gap:12px;
}
.as-item:last-child{border-bottom:none}
.as-item:hover,.as-item.active{
  background:rgba(59,158,221,.1);
}
.as-item-left{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  flex:1;
}
.as-item-icon{
  font-size:15px;
  width:22px;
  text-align:center;
  flex-shrink:0;
  opacity:.8;
}
.as-item-name{
  font-size:14px;
  color:rgba(255,255,255,.75);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.as-item-name strong{
  color:#fff;
  font-weight:600;
}
.as-item-type{
  font-size:11px;
  color:rgba(255,255,255,.25);
  font-family:"DM Mono",monospace;
  letter-spacing:.04em;
  white-space:nowrap;
  flex-shrink:0;
}
.as-item-custom{background:rgba(245,166,35,.04)}
.as-item-custom:hover{background:rgba(245,166,35,.08)}
.as-item-custom .as-item-name{color:rgba(255,255,255,.55)}
.as-item-custom .as-item-name strong{color:var(--amber)}
.as-hint{
  font-size:11px;
  color:rgba(255,255,255,.25);
  margin-top:8px;
  font-family:"DM Mono",monospace;
  letter-spacing:.03em;
  display:flex;
  align-items:center;
  gap:6px;
}
.as-hint::before{
  content:"";
  width:4px;
  height:4px;
  border-radius:50%;
  background:rgba(255,255,255,.2);
  flex-shrink:0;
}
.as-hint-warn{color:var(--amber)}
.as-hint-warn::before{background:var(--amber)}
.as-hint-max{color:#1db954}
.as-hint-max::before{background:#1db954}

@media(max-width:480px){
  .as-input{min-width:100px;font-size:16px}
  .as-item{padding:13px 14px}
  .as-item-name{font-size:15px}
}

/* ── SCROLL TO TOP ── */
.scroll-top{position:fixed;bottom:90px;right:24px;z-index:800;width:40px;height:40px;background:rgba(10,21,32,.9);border:0.5px solid rgba(255,255,255,.15);border-radius:50%;display:none;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;backdrop-filter:blur(8px)}
.scroll-top.show{display:flex}
.scroll-top:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-2px)}
@media(max-width:480px){.scroll-top{bottom:80px;right:16px}}

/* ── COOKIE CONSENT ── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:950;background:#0d1d2e;border-top:0.5px solid rgba(59,158,221,.2);padding:16px 5vw;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;box-shadow:0 -8px 32px rgba(0,0,0,.4);transform:translateY(100%);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.cookie-banner.show{transform:translateY(0)}
.cookie-text{font-size:13px;color:var(--muted);line-height:1.5;flex:1;min-width:200px}
.cookie-text a{color:var(--sky);text-decoration:none}
.cookie-text a:hover{text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.cookie-accept{background:var(--amber);color:var(--ink);border:none;border-radius:6px;padding:9px 20px;font-size:13px;font-weight:700;cursor:pointer;font-family:"Barlow",sans-serif;transition:all .2s}
.cookie-accept:hover{background:#f7b440}
.cookie-decline{background:rgba(255,255,255,.07);border:0.5px solid rgba(255,255,255,.15);border-radius:6px;padding:9px 16px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:"Barlow",sans-serif;transition:all .2s}
.cookie-decline:hover{background:rgba(255,255,255,.12);color:var(--white)}
@media(max-width:480px){.cookie-banner{flex-direction:column;align-items:flex-start}.cookie-btns{width:100%}.cookie-accept,.cookie-decline{flex:1;text-align:center}}

/* ── MOBILE NAV FIXES ── */
.nav-cta-desktop { display: flex; }
@media (max-width: 768px) {
  .nav-cta-desktop { display: none !important; }
  
  
}





/* ════════════════════════════════════════
   MOBILE NAV — clean implementation
   ════════════════════════════════════════ */

/* Hamburger button — hidden on desktop */
.nav-hamburger-btn {
  display: none;
  background: none;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 8px;
  cursor: pointer;
  padding: 8px 10px;
  flex-direction: column;
  gap: 5px;
  align-items: center;
  justify-content: center;
}
.ham-line {
  width: 20px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  display: block;
}

/* Mobile overlay — hidden by default */
.mobile-nav-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: #0A1520;
  z-index: 9999;
  flex-direction: column;
  overflow-y: auto;
}
.mobile-nav-overlay.open {
  display: flex !important;
}

/* Mobile nav header */
.mobile-nav-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.mobile-nav-close {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  color: var(--white);
  cursor: pointer;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Mobile nav links */
.mobile-nav-links {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.mobile-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 17px;
  font-weight: 600;
  color: var(--white);
  text-decoration: none;
  padding: 18px 24px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-family: inherit;
}
.mobile-nav-link::after {
  content: '›';
  color: rgba(255,255,255,.3);
  font-size: 20px;
}

/* Mobile nav divider */
.mobile-nav-divider {
  height: 1px;
  background: rgba(255,255,255,.08);
  margin: 8px 0;
  flex-shrink: 0;
}

/* Mobile nav actions */
.mobile-nav-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px 24px 32px;
  flex-shrink: 0;
}
.mobile-nav-waitlist {
  display: block;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--amber);
  text-decoration: none;
  padding: 14px 20px;
  border: 2px solid rgba(245,166,35,.5);
  border-radius: 10px;
  background: rgba(245,166,35,.06);
}
.mobile-nav-cta {
  width: 100%;
  padding: 14px;
  font-size: 16px;
  border-radius: 10px;
  text-align: center;
}
.mobile-nav-signin {
  display: block;
  text-align: center;
  font-size: 14px;
  color: rgba(255,255,255,.4);
  text-decoration: none;
  padding: 8px;
}

/* Mobile breakpoint */
@media (max-width: 768px) {
  .nav-hamburger-btn { display: flex !important; }
  .nav-links { display: none !important; }
  .nav-loggedout-wrap { display: none !important; }
  #nav-user-menu { display: none !important; }
  .nav-cta-desktop { display: none !important; }
}

/* ── OPPORTUNITY SCORE ── */
.opp-score-wrap { display:flex;flex-direction:column;gap:2px }
.opp-score-badge { display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;padding:3px 8px;border-radius:6px;white-space:nowrap }
.opp-score-label { font-size:11px;color:rgba(255,255,255,.4) }
.opp-green { background:rgba(29,185,84,.15);color:#1db954;border:1px solid rgba(29,185,84,.3) }
.opp-amber { background:rgba(245,166,35,.15);color:#F5A623;border:1px solid rgba(245,166,35,.3) }
.opp-orange { background:rgba(255,120,0,.15);color:#ff7800;border:1px solid rgba(255,120,0,.3) }
.opp-red { background:rgba(232,56,79,.15);color:#e8384f;border:1px solid rgba(232,56,79,.3) }
.score-info-btn { background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:16px;height:16px;font-size:10px;color:var(--white);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;margin-left:4px;vertical-align:middle }
.score-info-btn:hover { background:rgba(245,166,35,.2);border-color:var(--amber) }
