*{margin:0;padding:0;box-sizing:border-box}:root{--text:#fff;--muted:rgba(255,255,255,.68);--pink:#ff4fb8;--rose:#ff7a95;--violet:#8a5cff;--cyan:#25d7ff;--green:#35ffbd;--selected-accent:#ff7a95}html{scroll-behavior:smooth}body{min-height:100vh;background:radial-gradient(circle at 18% 18%,rgba(255,79,184,.25),transparent 34%),radial-gradient(circle at 82% 28%,rgba(138,92,255,.24),transparent 34%),radial-gradient(circle at 50% 100%,rgba(37,215,255,.12),transparent 32%),linear-gradient(180deg,#05050c 0%,#090817 55%,#05050c 100%);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}button,input{font:inherit}.page-glow{position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:72px 72px;mask-image:linear-gradient(to bottom,black,transparent 70%);opacity:.35;z-index:0}.container{width:min(1180px,calc(100% - 40px));margin:0 auto;position:relative;z-index:1}header{position:sticky;top:0;z-index:20;backdrop-filter:blur(18px);background:rgba(5,5,12,.62);border-bottom:1px solid rgba(255,255,255,.08)}.nav{height:74px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:-.04em;font-size:24px}.logo-mark{width:38px;height:38px;border-radius:14px;background:radial-gradient(circle at 28% 26%,#fff 0 7%,transparent 8%),linear-gradient(135deg,var(--pink),var(--violet));position:relative;box-shadow:0 0 28px rgba(255,79,184,.36)}.logo-mark:before{content:"";position:absolute;inset:10px 8px 8px;border:3px solid rgba(255,255,255,.88);border-top-color:transparent;border-radius:50%;transform:rotate(-28deg)}.logo span{background:linear-gradient(90deg,#fff,#ff9ecf 55%,#a889ff);-webkit-background-clip:text;background-clip:text;color:transparent}.nav-links{display:flex;align-items:center;gap:26px;color:var(--muted);font-size:14px}.nav-links a:hover{color:#fff}.nav-cta{padding:11px 18px;border-radius:999px;background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff!important;font-weight:700}.hero{min-height:calc(100vh - 74px);display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:46px;padding:82px 0 64px}.badge{display:inline-flex;align-items:center;gap:9px;padding:8px 13px;border:1px solid rgba(255,255,255,.13);border-radius:999px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.82);font-size:13px;margin-bottom:22px}.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 18px rgba(53,255,189,.7)}h1{font-size:clamp(48px,7vw,92px);line-height:.93;letter-spacing:-.075em;max-width:760px;margin-bottom:24px}.gradient-text{background:linear-gradient(90deg,#fff 0%,#ff7a95 34%,#ff4fb8 60%,#8a5cff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{max-width:610px;color:var(--muted);font-size:19px;line-height:1.65;margin-bottom:32px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;cursor:pointer;border-radius:999px;font-weight:800;padding:15px 24px;font-size:15px;transition:.2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--rose),var(--pink),var(--violet));color:#fff;box-shadow:0 20px 46px rgba(255,79,184,.34)}.btn-secondary{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.14)}.hero-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:590px}.point{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.78);font-size:14px}.check{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.09);color:#ff9ecf;border:1px solid rgba(255,255,255,.1);font-size:13px;flex:none}.phone-wrap{position:relative;display:flex;justify-content:center}.phone-glow{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,79,184,.3),rgba(138,92,255,.17),transparent 68%);filter:blur(8px);top:10%}.phone{position:relative;width:min(390px,100%);border:1px solid rgba(255,255,255,.16);border-radius:38px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04));padding:14px;box-shadow:0 34px 90px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.18);overflow:hidden}.screen{border-radius:28px;overflow:hidden;background:linear-gradient(rgba(0,0,0,.25),rgba(0,0,0,.8)),radial-gradient(circle at 55% 8%,rgba(255,79,184,.35),transparent 32%),linear-gradient(180deg,#181126,#06050a);min-height:620px;position:relative;padding:20px}.avatar,.companion-art,.selected-art{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,transparent 34%,rgba(0,0,0,.8)),radial-gradient(circle at 50% 30%,rgba(255,122,149,.28),transparent 36%),linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.02))}.avatar{height:290px;border-radius:24px;display:flex;align-items:flex-end;padding:18px}.avatar:before,.companion-art:before,.selected-art:before{content:"";position:absolute;width:156px;height:230px;border-radius:80px 80px 28px 28px;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(0,0,0,.55));left:50%;bottom:0;transform:translateX(-50%);box-shadow:0 0 70px rgba(255,79,184,.28)}.avatar-copy{position:relative;z-index:2}.avatar-copy strong{display:block;font-size:24px;letter-spacing:-.04em;margin-bottom:4px}.avatar-copy span{color:rgba(255,255,255,.68);font-size:13px}.chat-card{margin-top:16px;display:grid;gap:12px}.bubble,.msg{max-width:86%;padding:13px 14px;border-radius:18px;font-size:14px;line-height:1.45}.bubble.ai,.msg.ai{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.9)}.bubble.user,.msg.user{margin-left:auto;background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff}.feature-bar{margin-top:16px;display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.feature-bar div{text-align:center;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);padding:12px 8px;font-size:12px;color:rgba(255,255,255,.78)}section{padding:88px 0;position:relative;z-index:1}.section-head{text-align:center;max-width:760px;margin:0 auto 42px}.section-head h2{font-size:clamp(34px,4.5vw,58px);letter-spacing:-.06em;line-height:1;margin-bottom:16px}.section-head p{color:var(--muted);font-size:17px;line-height:1.65}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.card{min-height:218px;border-radius:26px;padding:22px;background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.045));border:1px solid rgba(255,255,255,.12)}.card-icon{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(255,79,184,.24),rgba(138,92,255,.22));border:1px solid rgba(255,255,255,.11);margin-bottom:18px;font-size:22px}.card h3{font-size:20px;letter-spacing:-.04em;margin-bottom:10px}.card p{color:rgba(255,255,255,.64);line-height:1.6;font-size:14px}.cta-panel{border-radius:34px;padding:54px;text-align:center;border:1px solid rgba(255,255,255,.14);background:radial-gradient(circle at 20% 20%,rgba(255,79,184,.22),transparent 34%),radial-gradient(circle at 80% 50%,rgba(138,92,255,.24),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.045));box-shadow:0 32px 90px rgba(0,0,0,.34)}.cta-panel h2{font-size:clamp(36px,5vw,64px);letter-spacing:-.07em;line-height:.98;margin-bottom:18px}.cta-panel p{max-width:640px;margin:0 auto 28px;color:var(--muted);font-size:17px;line-height:1.6}.app-section{display:none;padding:38px 0 86px}.app-shell{min-height:calc(100vh - 150px);border:1px solid rgba(255,255,255,.12);border-radius:34px;background:radial-gradient(circle at 20% 15%,rgba(255,79,184,.18),transparent 32%),radial-gradient(circle at 82% 20%,rgba(37,215,255,.11),transparent 28%),linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.035));overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.34)}.app-top{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.18)}.app-top h2{font-size:26px;letter-spacing:-.05em}.app-top p{color:var(--muted);margin-top:5px;font-size:14px}.small-btn{border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.07);color:#fff;border-radius:999px;padding:10px 14px;cursor:pointer}.companion-grid{padding:26px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.companion-card{position:relative;min-height:500px;border:1px solid rgba(255,255,255,.13);border-radius:28px;background:rgba(255,255,255,.06);overflow:hidden;cursor:pointer;transition:.22s}.companion-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.26);box-shadow:0 24px 70px rgba(255,79,184,.16)}.companion-art{height:290px;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.92)),radial-gradient(circle at 50% 20%,var(--accent),transparent 44%),linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.025))}.companion-body{padding:20px}.companion-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.companion-body h3{font-size:23px;letter-spacing:-.05em}.tag{font-size:11px;color:rgba(255,255,255,.76);padding:6px 9px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);white-space:nowrap}.companion-body p{color:rgba(255,255,255,.66);line-height:1.55;font-size:14px;margin-bottom:16px}.sample-message{padding:13px;border-radius:18px;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.84);font-size:13px;line-height:1.45;margin-bottom:16px}.choose-btn{width:100%;border-radius:999px;border:0;color:#fff;background:linear-gradient(135deg,var(--accent),var(--violet));padding:13px 16px;cursor:pointer;font-weight:800}.chat-layout{display:none;grid-template-columns:320px 1fr;min-height:calc(100vh - 150px)}.chat-sidebar{border-right:1px solid rgba(255,255,255,.1);padding:24px;background:rgba(0,0,0,.16)}.selected-profile{border-radius:28px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}.selected-art{height:280px;background:linear-gradient(180deg,transparent 42%,rgba(0,0,0,.88)),radial-gradient(circle at 50% 22%,var(--selected-accent),transparent 42%),linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.025))}.selected-info{padding:18px}.selected-info h3{font-size:24px;letter-spacing:-.05em;margin-bottom:4px}.selected-info p{color:rgba(255,255,255,.64);line-height:1.55;font-size:14px}.status-line{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.68);font-size:13px;margin-bottom:16px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green)}.sidebar-actions{display:grid;gap:10px;margin-top:16px}.sidebar-actions button{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.07);color:#fff;border-radius:16px;padding:13px;text-align:left;cursor:pointer;display:flex;justify-content:space-between;gap:10px}.locked{color:rgba(255,255,255,.45)}.chat-main{display:flex;flex-direction:column;min-width:0}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.12)}.chat-title{display:flex;align-items:center;gap:12px}.mini-avatar{width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,var(--selected-accent),var(--violet));box-shadow:0 0 24px rgba(255,79,184,.25)}.chat-title h3{font-size:19px;letter-spacing:-.04em}.chat-title span{color:rgba(255,255,255,.58);font-size:12px}.chat-tools{display:flex;gap:10px}.chat-tools button{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:#fff;border-radius:999px;padding:10px 13px;cursor:pointer;font-size:13px}.messages{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;min-height:520px;max-height:680px}.msg{max-width:min(620px,84%);font-size:15px;animation:fadeIn .22s ease both}.msg.ai{align-self:flex-start;border-bottom-left-radius:7px}.msg.user{align-self:flex-end;border-bottom-right-radius:7px}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.typing{display:none;align-self:flex-start;margin-left:24px;padding:13px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.58);font-size:13px}.composer{padding:18px 24px 24px;border-top:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.16)}.composer-inner{display:flex;gap:10px;align-items:center;padding:8px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12)}.composer-inner input{flex:1;min-width:0;background:transparent;border:0;outline:0;color:#fff;padding:0 12px;font-size:15px}.composer-inner input::placeholder{color:rgba(255,255,255,.42)}.send-btn{width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--pink),var(--violet));font-weight:900}.hint{margin-top:10px;color:rgba(255,255,255,.42);font-size:12px;text-align:center}footer{padding:34px 0 46px;color:rgba(255,255,255,.52);font-size:14px;border-top:1px solid rgba(255,255,255,.08)}.footer-row{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.footer-links{display:flex;gap:18px;flex-wrap:wrap}@media(max-width:1060px){.companion-grid{grid-template-columns:repeat(2,1fr)}.chat-layout{grid-template-columns:1fr}.chat-sidebar{display:none}}@media(max-width:920px){.hero{grid-template-columns:1fr;padding-top:54px}.phone-wrap{order:-1}.screen{min-height:560px}.cards{grid-template-columns:repeat(2,1fr)}.nav-links a:not(.nav-cta){display:none}}@media(max-width:640px){.companion-grid{grid-template-columns:1fr}.companion-card{min-height:auto}.chat-header{flex-direction:column;align-items:flex-start}.chat-tools{width:100%;overflow-x:auto}.msg{max-width:94%}}@media(max-width:580px){.container{width:min(100% - 28px,1180px)}.nav{height:66px}.logo{font-size:21px}.hero{padding-top:34px}.hero p{font-size:16px}.hero-points,.cards{grid-template-columns:1fr}.cta-panel{padding:34px 18px}.composer-inner{border-radius:24px}}

/* === Youforia v1.2 mobile optimization === */
/* Better handling for iPhone/Android viewport height, safe areas, and touch UI. */

html,
body {
  width: 100%;
  max-width: 100%;
}

body {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

button,
a,
input {
  -webkit-tap-highlight-color: transparent;
}

input,
button {
  touch-action: manipulation;
}

/* Dynamic viewport units solve mobile browser address-bar issues. */
@supports (height: 100dvh) {
  .hero {
    min-height: calc(100dvh - 74px);
  }

  .app-shell {
    height: calc(100dvh - 112px);
  }
}

/* Tablet and small laptop cleanup */
@media (max-width: 920px) {
  .container {
    width: min(100% - 32px, 1180px);
  }

  .hero {
    gap: 32px;
    padding: 42px 0 52px;
  }

  .phone-wrap {
    order: 0;
  }

  .phone {
    width: min(360px, 100%);
  }

  .screen {
    min-height: 520px;
  }

  .app-shell {
    border-radius: 28px;
  }
}

/* Main phone optimization */
@media (max-width: 700px) {
  header {
    position: sticky;
  }

  .nav {
    height: 64px;
  }

  .logo {
    font-size: 20px;
  }

  .logo-mark {
    width: 34px;
    height: 34px;
    border-radius: 12px;
  }

  .nav-links {
    gap: 10px;
  }

  .nav-links a:not(.nav-cta) {
    display: none;
  }

  .nav-cta {
    padding: 10px 13px;
    font-size: 13px;
  }

  .hero {
    min-height: auto;
    display: block;
    padding: 34px 0 44px;
  }

  h1 {
    font-size: clamp(42px, 13vw, 64px);
    line-height: 0.95;
    letter-spacing: -0.07em;
  }

  .hero p {
    font-size: 16px;
    line-height: 1.55;
    margin-bottom: 24px;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-bottom: 24px;
  }

  .btn {
    width: 100%;
    padding: 15px 18px;
  }

  .hero-points {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .phone-wrap {
    margin-top: 34px;
  }

  .phone {
    width: 100%;
    max-width: 380px;
    border-radius: 30px;
    padding: 10px;
  }

  .screen {
    min-height: 500px;
    border-radius: 22px;
    padding: 16px;
  }

  .avatar {
    height: 240px;
    border-radius: 20px;
  }

  .avatar:before {
    height: 200px;
  }

  section {
    padding: 58px 0;
  }

  .section-head {
    margin-bottom: 26px;
  }

  .section-head h2 {
    font-size: clamp(34px, 10vw, 48px);
  }

  .section-head p {
    font-size: 15px;
  }

  .cards {
    grid-template-columns: 1fr;
  }

  .card {
    min-height: auto;
    border-radius: 22px;
  }

  .cta-panel {
    border-radius: 26px;
    padding: 30px 18px;
  }

  .cta-panel h2 {
    font-size: clamp(34px, 11vw, 48px);
  }

  .app-section {
    padding: 14px 0 22px;
  }

  .app-section .container {
    width: 100%;
  }

  .app-shell {
    width: 100%;
    height: calc(100svh - 88px);
    min-height: 0;
    max-height: none;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
  }

  @supports (height: 100dvh) {
    .app-shell {
      height: calc(100dvh - 88px);
    }
  }

  .app-top {
    padding: 16px;
    align-items: flex-start;
  }

  .app-top h2 {
    font-size: 22px;
  }

  .app-top p {
    font-size: 13px;
    line-height: 1.4;
  }

  .small-btn {
    padding: 9px 11px;
    font-size: 13px;
    white-space: nowrap;
  }

  .companion-grid {
    padding: 16px;
    grid-template-columns: 1fr;
    gap: 14px;
    overflow-y: auto;
    max-height: calc(100dvh - 170px);
  }

  .companion-card {
    min-height: auto;
    border-radius: 24px;
  }

  .companion-art {
    height: 230px;
  }

  .companion-art:before {
    height: 196px;
  }

  .companion-body {
    padding: 16px;
  }

  .companion-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .chat-layout {
    height: 100%;
    min-height: 0;
    grid-template-columns: 1fr;
  }

  .chat-main {
    height: 100%;
    min-height: 0;
  }

  .chat-header {
    flex-direction: row;
    align-items: center;
    padding: 13px 14px;
    gap: 10px;
  }

  .chat-title {
    min-width: 0;
  }

  .chat-title h3 {
    font-size: 17px;
  }

  .chat-title span {
    display: block;
    max-width: 170px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .mini-avatar {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    flex: none;
  }

  .chat-tools {
    gap: 7px;
    overflow-x: auto;
    flex-shrink: 0;
  }

  .chat-tools button {
    padding: 8px 10px;
    font-size: 12px;
    white-space: nowrap;
  }

  .messages {
    min-height: 0;
    max-height: none;
    padding: 14px;
    gap: 12px;
    -webkit-overflow-scrolling: touch;
  }

  .msg {
    max-width: 88%;
    font-size: 15px;
    padding: 12px 14px;
  }

  .typing {
    margin-left: 14px;
    margin-bottom: 8px;
  }

  .composer {
    padding: 10px 12px calc(12px + env(safe-area-inset-bottom));
  }

  .composer-inner {
    border-radius: 22px;
    padding: 7px;
  }

  .composer-inner input {
    font-size: 16px; /* prevents iPhone auto-zoom */
    padding: 0 8px;
  }

  .send-btn {
    width: 42px;
    height: 42px;
    flex: none;
  }

  .hint {
    display: none;
  }

  footer {
    padding: 24px 0 34px;
  }

  .footer-row {
    flex-direction: column;
  }

  .footer-links {
    flex-direction: column;
    gap: 10px;
  }
}

/* Extra small phones */
@media (max-width: 390px) {
  .container {
    width: min(100% - 24px, 1180px);
  }

  h1 {
    font-size: 40px;
  }

  .badge {
    font-size: 12px;
  }

  .nav-cta {
    padding: 9px 11px;
  }

  .chat-tools button {
    padding: 7px 9px;
  }

  .msg {
    max-width: 92%;
  }
}

/* Landscape phones */
@media (max-height: 520px) and (orientation: landscape) {
  .hero {
    padding: 24px 0;
  }

  .phone-wrap {
    display: none;
  }

  .app-shell {
    height: calc(100dvh - 76px);
  }

  .app-top {
    padding: 12px 16px;
  }

  .companion-grid {
    grid-template-columns: repeat(2, 1fr);
    max-height: calc(100dvh - 140px);
  }

  .companion-art {
    height: 160px;
  }

  .chat-header {
    padding: 10px 14px;
  }

  .composer {
    padding: 8px 12px calc(8px + env(safe-area-inset-bottom));
  }
}


/* === Youforia v1.3 cleanup === */
/* Fixes desktop empty space below composer + mobile horizontal overflow. */

body {
  overflow-x: hidden !important;
}

/* Desktop/tablet: chat panel should fill shell and composer should sit at bottom. */
#chatView.chat-layout,
.chat-layout {
  height: 100%;
  min-height: 0;
}

.app-shell {
  overflow: hidden;
}

.chat-main {
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.messages {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none !important;
}

.composer {
  flex: 0 0 auto;
}

/* Prevent companion cards from creating side-scroll on mobile. */
.app-section,
.app-section .container,
.app-shell,
#selectionView,
.companion-grid,
.companion-card,
.chat-layout,
.chat-main {
  max-width: 100%;
}

/* Mobile: make the app a true full-width app surface. */
@media (max-width: 700px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  .app-section {
    width: 100%;
    overflow-x: hidden;
  }

  .app-section .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0;
    margin: 0;
  }

  .app-shell {
    width: 100%;
    max-width: 100%;
    border-left: 0;
    border-right: 0;
    overflow-x: hidden;
  }

  .app-top {
    width: 100%;
    box-sizing: border-box;
  }

  .companion-grid {
    width: 100%;
    max-width: 100%;
    padding: 14px;
    box-sizing: border-box;
    overflow-x: hidden;
  }

  .companion-card {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .companion-art {
    width: 100%;
    max-width: 100%;
  }

  .chat-layout {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  .chat-header,
  .messages,
  .composer {
    width: 100%;
    box-sizing: border-box;
  }

  .chat-tools {
    max-width: 145px;
  }

  .chat-tools button {
    flex: 0 0 auto;
  }

  .msg {
    word-break: break-word;
    overflow-wrap: anywhere;
  }
}

/* Very small phones: tighten header so it does not overflow. */
@media (max-width: 380px) {
  .logo span {
    font-size: 18px;
  }

  .nav-cta {
    font-size: 12px;
    padding: 9px 10px;
  }

  .app-top {
    gap: 10px;
  }

  .small-btn {
    font-size: 12px;
    padding: 8px 10px;
  }
}


/* === Youforia v1.6 Z Fold / mobile chat fix === */
/* Clean mobile behavior: no forced body locking, no auto keyboard pop, no washed-out overlay. */

body.app-mode footer {
  display: none;
}

body.app-mode {
  overflow-x: hidden !important;
}

/* Desktop: keep composer at the bottom of the app shell. */
#chatView.chat-layout,
.chat-layout {
  height: 100%;
  min-height: 0;
}

.chat-main {
  min-height: 0;
}

.messages {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none !important;
}

.composer {
  flex: 0 0 auto;
}

/* Mobile and Z Fold cover screen */
@media (max-width: 700px) {
  body.app-mode {
    position: static !important;
    height: auto !important;
    overflow-y: auto !important;
    background: #05050c;
  }

  body.app-mode header {
    display: block !important;
    position: sticky;
    top: 0;
  }

  body.app-mode .app-section {
    position: static !important;
    height: auto !important;
    padding: 0;
    overflow: visible;
  }

  body.app-mode .app-section .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0;
    margin: 0;
  }

  body.app-mode .app-shell {
    width: 100%;
    max-width: 100%;
    min-height: calc(100svh - 64px);
    height: auto !important;
    max-height: none !important;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    overflow: hidden;
  }

  body.app-mode.chat-active {
    overflow: hidden !important;
  }

  body.app-mode.chat-active .app-section {
    height: calc(100svh - 64px) !important;
    overflow: hidden;
  }

  body.app-mode.chat-active .app-shell {
    height: calc(100svh - 64px) !important;
    min-height: 0;
  }

  body.app-mode.chat-active .chat-layout {
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  body.app-mode.chat-active .chat-main {
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  body.app-mode.chat-active .messages {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 14px 14px 18px;
    -webkit-overflow-scrolling: touch;
  }

  body.app-mode.chat-active .composer {
    position: relative;
    flex: 0 0 auto;
    background: rgba(6, 6, 14, 0.96);
    border-top: 1px solid rgba(255,255,255,.12);
    padding: 10px 12px calc(12px + env(safe-area-inset-bottom));
  }

  .chat-header {
    padding: 12px 14px;
  }

  .chat-title span {
    max-width: 170px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .chat-tools {
    max-width: 160px;
    overflow-x: auto;
  }

  .chat-tools button {
    white-space: nowrap;
    font-size: 12px;
    padding: 8px 10px;
  }

  .composer-inner input {
    font-size: 16px;
  }

  .msg {
    max-width: 92%;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
}

/* Z Fold unfolded / small tablet */
@media (min-width: 701px) and (max-width: 980px) {
  .app-section .container {
    width: min(100% - 24px, 920px);
  }

  .companion-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .chat-layout {
    grid-template-columns: 1fr;
  }

  .chat-sidebar {
    display: none;
  }

  .app-shell {
    min-height: calc(100svh - 110px);
  }
}


/* === Youforia v1.7 color / opacity fix === */
/* Makes the UI richer, less transparent, and closer to a premium dark app. */

body {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 79, 184, 0.38), transparent 34%),
    radial-gradient(circle at 82% 28%, rgba(138, 92, 255, 0.34), transparent 34%),
    radial-gradient(circle at 50% 100%, rgba(37, 215, 255, 0.18), transparent 32%),
    linear-gradient(180deg, #060411 0%, #0b071b 52%, #05050c 100%);
}

header {
  background: rgba(5, 4, 13, 0.92) !important;
}

.app-shell {
  background:
    radial-gradient(circle at 18% 14%, rgba(255,79,184,.28), transparent 32%),
    radial-gradient(circle at 84% 18%, rgba(37,215,255,.18), transparent 28%),
    linear-gradient(180deg, rgba(28, 24, 42, 0.98), rgba(12, 13, 24, 0.98)) !important;
  border-color: rgba(255,255,255,.2) !important;
}

.chat-sidebar {
  background:
    radial-gradient(circle at 30% 12%, rgba(255,79,184,.20), transparent 35%),
    linear-gradient(180deg, rgba(34, 25, 43, 0.98), rgba(11, 11, 20, 0.98)) !important;
}

.chat-main {
  background:
    radial-gradient(circle at 24% 24%, rgba(255,79,184,.18), transparent 34%),
    radial-gradient(circle at 85% 20%, rgba(37,215,255,.16), transparent 34%),
    linear-gradient(180deg, rgba(24, 28, 44, 0.98), rgba(10, 12, 22, 0.98)) !important;
}

.chat-header,
.app-top {
  background: rgba(18, 17, 29, 0.96) !important;
  border-color: rgba(255,255,255,.18) !important;
}

.messages {
  background:
    radial-gradient(circle at 25% 10%, rgba(255,79,184,.12), transparent 34%),
    radial-gradient(circle at 86% 22%, rgba(37,215,255,.12), transparent 35%),
    linear-gradient(180deg, rgba(18, 22, 36, 0.96), rgba(11, 13, 22, 0.96)) !important;
}

.composer {
  background: rgba(8, 8, 18, 0.98) !important;
  border-color: rgba(255,255,255,.16) !important;
}

.composer-inner {
  background: rgba(4, 5, 12, 0.96) !important;
  border-color: rgba(255,255,255,.18) !important;
}

.msg.ai,
.bubble.ai {
  background: rgba(67, 72, 94, 0.88) !important;
  border-color: rgba(255,255,255,.18) !important;
  color: rgba(255,255,255,.96) !important;
}

.msg.user,
.bubble.user {
  background: linear-gradient(135deg, #ff4fb8, #b35cff) !important;
  color: #fff !important;
  box-shadow: 0 12px 34px rgba(255,79,184,.30) !important;
}

.selected-profile,
.companion-card,
.card,
.cta-panel,
.phone {
  background: linear-gradient(180deg, rgba(44, 38, 58, 0.96), rgba(22, 20, 33, 0.96)) !important;
  border-color: rgba(255,255,255,.18) !important;
}

.selected-art,
.companion-art,
.avatar {
  background:
    linear-gradient(180deg, transparent 38%, rgba(0,0,0,.90)),
    radial-gradient(circle at 50% 24%, var(--selected-accent, #ff7a95), transparent 42%),
    linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.04)) !important;
}

.companion-card .companion-art {
  background:
    linear-gradient(180deg, transparent 40%, rgba(0,0,0,.92)),
    radial-gradient(circle at 50% 20%, var(--accent), transparent 44%),
    linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.04)) !important;
}

.selected-info,
.companion-body {
  background: rgba(24, 20, 34, 0.82);
}

.side-action,
.sidebar-actions button,
.chat-tools button,
.small-btn,
.feature-bar div {
  background: rgba(50, 47, 66, 0.92) !important;
  border-color: rgba(255,255,255,.20) !important;
  color: #fff !important;
}

.tag,
.badge {
  background: rgba(55, 50, 72, 0.92) !important;
  border-color: rgba(255,255,255,.18) !important;
}

/* Mobile needs even stronger contrast because Chrome/Samsung viewport changes can wash translucent layers out. */
@media (max-width: 700px) {
  .app-shell,
  .chat-main,
  .messages {
    background-color: #0b0d18 !important;
  }

  .chat-header {
    background: #11101d !important;
  }

  .app-top {
    background: #151020 !important;
  }

  .composer {
    background: #070812 !important;
  }

  .msg.ai {
    background: #3a4050 !important;
  }

  .companion-card,
  .selected-profile {
    background: #1b1726 !important;
  }
}


/* === Youforia v1.8 mobile fullscreen chat fix === */
/* Stops Chrome/Z Fold from scrolling the whole page to the input and hiding the AI message. */

:root {
  --youforia-app-height: 100dvh;
}

/* Fullscreen app behavior only while actually inside chat on mobile. */
@media (max-width: 700px) {
  body.app-mode.chat-active {
    position: fixed !important;
    inset: 0 !important;
    width: 100% !important;
    height: var(--youforia-app-height) !important;
    overflow: hidden !important;
    background: #05050c !important;
  }

  body.app-mode.chat-active header,
  body.app-mode.chat-active footer {
    display: none !important;
  }

  body.app-mode.chat-active .app-section {
    position: fixed !important;
    inset: 0 !important;
    width: 100% !important;
    height: var(--youforia-app-height) !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: #05050c !important;
  }

  body.app-mode.chat-active .app-section .container {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.app-mode.chat-active .app-shell {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: block !important;
    overflow: hidden !important;
    background:
      radial-gradient(circle at 20% 18%, rgba(255,79,184,.22), transparent 34%),
      radial-gradient(circle at 84% 24%, rgba(37,215,255,.14), transparent 32%),
      linear-gradient(180deg, #171427 0%, #0b0d18 100%) !important;
  }

  body.app-mode.chat-active #selectionView {
    display: none !important;
  }

  body.app-mode.chat-active #chatView.chat-layout {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  body.app-mode.chat-active .chat-sidebar {
    display: none !important;
  }

  body.app-mode.chat-active .chat-main {
    flex: 1 1 auto !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    background:
      radial-gradient(circle at 24% 20%, rgba(255,79,184,.18), transparent 34%),
      radial-gradient(circle at 85% 22%, rgba(37,215,255,.13), transparent 35%),
      linear-gradient(180deg, #171b2c 0%, #0b0d18 100%) !important;
  }

  body.app-mode.chat-active .chat-header {
    flex: 0 0 auto !important;
    padding: 10px 12px !important;
    background: #11101d !important;
    border-bottom: 1px solid rgba(255,255,255,.16) !important;
  }

  body.app-mode.chat-active .mini-avatar {
    width: 34px !important;
    height: 34px !important;
    border-radius: 12px !important;
  }

  body.app-mode.chat-active .chat-title {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  body.app-mode.chat-active .chat-title h3 {
    font-size: 16px !important;
  }

  body.app-mode.chat-active .chat-title span {
    font-size: 11px !important;
    max-width: 165px !important;
  }

  body.app-mode.chat-active .chat-tools {
    max-width: 145px !important;
    flex: 0 0 auto !important;
    overflow-x: auto !important;
    scrollbar-width: none;
  }

  body.app-mode.chat-active .chat-tools::-webkit-scrollbar {
    display: none;
  }

  body.app-mode.chat-active .chat-tools button {
    padding: 7px 9px !important;
    font-size: 11px !important;
    white-space: nowrap !important;
  }

  body.app-mode.chat-active .messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: auto !important;
    padding: 12px 12px 14px !important;
    -webkit-overflow-scrolling: touch !important;
    background:
      radial-gradient(circle at 28% 12%, rgba(255,79,184,.13), transparent 34%),
      radial-gradient(circle at 86% 22%, rgba(37,215,255,.11), transparent 35%),
      linear-gradient(180deg, #151a2a 0%, #0b0d18 100%) !important;
  }

  body.app-mode.chat-active .msg {
    max-width: 92% !important;
    font-size: 14px !important;
    line-height: 1.42 !important;
    padding: 11px 12px !important;
  }

  body.app-mode.chat-active .typing {
    flex: 0 0 auto !important;
    margin: 0 0 8px 12px !important;
  }

  body.app-mode.chat-active .composer {
    flex: 0 0 auto !important;
    position: relative !important;
    z-index: 10 !important;
    padding: 9px 10px calc(9px + env(safe-area-inset-bottom)) !important;
    background: #070812 !important;
    border-top: 1px solid rgba(255,255,255,.16) !important;
  }

  body.app-mode.chat-active .composer-inner {
    border-radius: 22px !important;
    padding: 6px !important;
    background: #04050c !important;
  }

  body.app-mode.chat-active .composer-inner input {
    font-size: 16px !important;
    padding: 0 8px !important;
  }

  body.app-mode.chat-active .send-btn {
    width: 40px !important;
    height: 40px !important;
    flex: 0 0 auto !important;
  }

  body.app-mode.chat-active .hint {
    display: none !important;
  }
}


/* === Youforia v1.9 final brand update === */
/* New cosmic logo, richer site branding, and final pink/purple/blue palette. */

:root {
  --pink: #ff58bf;
  --rose: #ff7aa8;
  --violet: #9b5cff;
  --cyan: #4aa8ff;
  --deep: #05030d;
}

body {
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 88, 191, 0.34), transparent 33%),
    radial-gradient(circle at 86% 22%, rgba(74, 168, 255, 0.24), transparent 34%),
    radial-gradient(circle at 52% 100%, rgba(155, 92, 255, 0.16), transparent 34%),
    linear-gradient(180deg, #05030d 0%, #0b0619 50%, #05050c 100%) !important;
}

.logo {
  gap: 12px;
}

.logo-img {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  object-fit: cover;
  box-shadow: 0 0 24px rgba(255, 88, 191, 0.38);
}

.logo-mark {
  display: none !important;
}

.logo span {
  background: linear-gradient(90deg, #fff, #ff8ed0 45%, #69a7ff 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

.nav-cta,
.btn-primary,
.send-btn {
  background: linear-gradient(135deg, #ff5aaa, #c05cff, #6f91ff) !important;
  box-shadow: 0 18px 44px rgba(255, 88, 191, 0.32) !important;
}

.gradient-text {
  background: linear-gradient(90deg, #ff8ed0 0%, #d56cff 48%, #62a8ff 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

.brand-banner-section {
  padding-top: 18px;
  padding-bottom: 74px;
}

.brand-banner {
  border-radius: 34px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.16);
  background: #05030d;
  box-shadow:
    0 30px 90px rgba(0,0,0,.42),
    0 0 80px rgba(155,92,255,.12);
}

.brand-banner img {
  display: block;
  width: 100%;
  height: auto;
}

.app-shell {
  border-color: rgba(255,255,255,.18) !important;
  box-shadow:
    0 30px 90px rgba(0,0,0,.42),
    0 0 70px rgba(255,88,191,.08) !important;
}

.msg.user,
.bubble.user {
  background: linear-gradient(135deg, #ff5aaa, #b85cff) !important;
}

.mini-avatar,
.selected-art,
.companion-art,
.avatar {
  --selected-accent: #ff5aaa;
}

/* Make header logo fit better on mobile. */
@media (max-width: 700px) {
  .logo-img {
    width: 38px;
    height: 38px;
    border-radius: 12px;
  }

  .logo span {
    font-size: 20px;
  }

  .brand-banner-section {
    padding-top: 10px;
    padding-bottom: 50px;
  }

  .brand-banner {
    border-radius: 24px;
  }
}

@media (max-width: 380px) {
  .logo-img {
    width: 34px;
    height: 34px;
  }

  .logo span {
    font-size: 18px;
  }
}


/* === Youforia v2.0 header logo sizing fix === */
/* Hard override so the new logo cannot render oversized in the nav. */

header .nav {
  height: 78px !important;
  overflow: hidden !important;
}

header .logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  height: 78px !important;
  max-height: 78px !important;
  overflow: hidden !important;
}

header .logo .logo-img,
.logo-img {
  display: block !important;
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  max-width: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  border-radius: 13px !important;
  object-fit: cover !important;
  object-position: center !important;
}

header .logo span {
  display: inline-block !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

@media (max-width: 700px) {
  header .nav {
    height: 66px !important;
  }

  header .logo {
    height: 66px !important;
    max-height: 66px !important;
    gap: 10px !important;
  }

  header .logo .logo-img,
  .logo-img {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    border-radius: 11px !important;
  }

  header .logo span {
    font-size: 20px !important;
  }
}

@media (max-width: 390px) {
  header .logo .logo-img,
  .logo-img {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
  }

  header .logo span {
    font-size: 18px !important;
  }
}


/* === Youforia v2.2 transparent header logo fix === */
/* Fixes the visible dark square/block next to the logo by using a transparent icon treatment. */

header {
  background:
    radial-gradient(circle at 9% 50%, rgba(255, 88, 191, 0.12), transparent 23%),
    radial-gradient(circle at 90% 50%, rgba(111, 145, 255, 0.12), transparent 28%),
    linear-gradient(90deg, #06030d 0%, #080512 22%, #070511 78%, #06030d 100%) !important;
  border-bottom: none !important;
  overflow: hidden !important;
}

header::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(
      90deg,
      rgba(255, 88, 191, 0.065) 0%,
      rgba(255, 88, 191, 0.018) 7%,
      rgba(0,0,0,0) 18%,
      rgba(0,0,0,0) 82%,
      rgba(111,145,255,0.018) 93%,
      rgba(111,145,255,0.065) 100%
    ) !important;
}

header::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  height: 1px !important;
  background:
    linear-gradient(
      90deg,
      rgba(255,255,255,0) 0%,
      rgba(255,88,191,0.10) 9%,
      rgba(255,255,255,0.14) 50%,
      rgba(111,145,255,0.10) 91%,
      rgba(255,255,255,0) 100%
    ) !important;
  pointer-events: none !important;
}

header .container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding-left: 26px !important;
  padding-right: 26px !important;
}

header .nav {
  width: 100% !important;
  max-width: none !important;
  height: 78px !important;
  overflow: visible !important;
  position: relative !important;
  z-index: 2 !important;
}

header .logo {
  height: 78px !important;
  max-height: 78px !important;
  overflow: visible !important;
}

/* Important: no more square image block. */
header .logo .logo-img,
.logo-img {
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  max-width: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  object-fit: contain !important;
  object-position: center !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  filter:
    drop-shadow(0 0 10px rgba(255, 88, 191, 0.42))
    drop-shadow(0 0 12px rgba(111, 145, 255, 0.20)) !important;
}

/* Add a soft glow behind the transparent mark without a square edge. */
header .logo::before {
  content: "" !important;
  position: absolute !important;
  left: 15px !important;
  width: 68px !important;
  height: 68px !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle, rgba(255, 88, 191, 0.13), rgba(111,145,255,0.06) 42%, transparent 70%) !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

header .logo span {
  font-size: 24px !important;
  line-height: 1 !important;
}

@media (max-width: 700px) {
  header .container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  header .nav,
  header .logo {
    height: 66px !important;
    max-height: 66px !important;
  }

  header .logo .logo-img,
  .logo-img {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
  }

  header .logo::before {
    left: 7px !important;
    width: 56px !important;
    height: 56px !important;
  }

  header .logo span {
    font-size: 20px !important;
  }
}

@media (max-width: 390px) {
  header .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  header .logo .logo-img,
  .logo-img {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
  }

  header .logo span {
    font-size: 18px !important;
  }
}


/* === Youforia v2.3 FINAL header no-box fix === */
/* The red-arrow issue was caused by header/nav overlay blocks and container-edge glow.
   This removes every header pseudo-layer and makes the top bar one clean full-width surface. */

header,
body header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  width: 100% !important;
  max-width: none !important;
  background: rgba(5, 4, 13, 0.96) !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow: none !important;
  overflow: visible !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

/* Kill ALL header pseudo layers that created visible boxed edges. */
header::before,
header::after,
header .nav::before,
header .nav::after,
header .container::before,
header .container::after,
header .logo::before,
header .logo::after {
  content: none !important;
  display: none !important;
  background: none !important;
  box-shadow: none !important;
}

/* Header container should span full screen, not a centered boxed region. */
header .container,
header .container.nav,
body header .container,
body header .container.nav {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding-left: 28px !important;
  padding-right: 28px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Nav itself should not have any separate visible background. */
header .nav,
body header .nav {
  width: 100% !important;
  max-width: none !important;
  height: 78px !important;
  min-height: 78px !important;
  max-height: 78px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Keep logo clean and remove any square/block look. */
header .logo,
body header .logo {
  height: 78px !important;
  max-height: 78px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

header .logo .logo-img,
body header .logo .logo-img,
.logo-img {
  display: block !important;
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  max-width: 46px !important;
  min-height: 46px !important;
  max-height: 46px !important;
  object-fit: contain !important;
  object-position: center !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  filter:
    drop-shadow(0 0 10px rgba(255, 88, 191, 0.42))
    drop-shadow(0 0 12px rgba(111, 145, 255, 0.20)) !important;
}

header .logo span,
body header .logo span {
  font-size: 24px !important;
  line-height: 1 !important;
  background: linear-gradient(90deg, #ffffff, #ff8ed0 45%, #69a7ff 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

/* Keep links and CTA clean, no hidden parent box. */
header .nav-links,
body header .nav-links {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

header .nav-cta,
body header .nav-cta {
  background: linear-gradient(135deg, #ff5aaa, #c05cff, #6f91ff) !important;
  box-shadow: 0 12px 28px rgba(255, 88, 191, 0.28) !important;
}

/* Optional full-width soft bottom glow without vertical edges. */
header {
  background:
    linear-gradient(180deg, rgba(8, 5, 18, 0.98), rgba(5, 4, 13, 0.96)) !important;
}

@media (max-width: 700px) {
  header .container,
  header .container.nav,
  body header .container,
  body header .container.nav {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  header .nav,
  body header .nav,
  header .logo,
  body header .logo {
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
  }

  header .logo .logo-img,
  body header .logo .logo-img,
  .logo-img {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
  }

  header .logo span,
  body header .logo span {
    font-size: 20px !important;
  }
}

@media (max-width: 390px) {
  header .container,
  header .container.nav,
  body header .container,
  body header .container.nav {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  header .logo .logo-img,
  body header .logo .logo-img,
  .logo-img {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
  }

  header .logo span,
  body header .logo span {
    font-size: 18px !important;
  }
}
