@import url('https://fonts.googleapis.com/css2?family=Urbanist:wght@400;500;600;700;800;900&display=swap');
:root{--bg:#0b1020;--panel:#131b2f;--panel2:#18233b;--text:#f1f5ff;--muted:#9fb0cc;--line:#2b3a5b;--accent:#9ee8d8;--accent2:#b8a7ff;--danger:#ff9aa6;--ok:#9ff5bd}*{box-sizing:border-box}body{margin:0;font-family:'Urbanist',ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;background:radial-gradient(circle at 15% 0,rgba(158,232,216,.16),transparent 26%),radial-gradient(circle at 90% 0,rgba(184,167,255,.16),transparent 28%),var(--bg);color:var(--text);line-height:1.55}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.topbar{position:sticky;top:0;z-index:3;display:flex;justify-content:space-between;align-items:center;padding:14px min(4vw,42px);background:rgba(11,16,32,.75);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08)}.brand{font-weight:850;color:var(--text);letter-spacing:.2px;display:flex;gap:10px;align-items:center}.orb{width:28px;height:28px;border-radius:999px;background:radial-gradient(circle at 35% 25%,#fff,var(--accent) 30%,#6d7cff 72%);box-shadow:0 0 28px rgba(158,232,216,.4)}nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}nav a{color:var(--muted);font-weight:700;font-size:14px}.container{width:min(1100px,92vw);margin:0 auto;padding:34px 0 72px}.narrow{width:min(650px,92vw)}.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;min-height:70vh}.card,.panel{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.1);border-radius:26px;padding:24px;box-shadow:0 24px 80px rgba(0,0,0,.24)}.panel{background:rgba(19,27,47,.72)}h1{font-size:clamp(34px,6vw,72px);line-height:1.02;margin:0 0 18px}h2{font-size:28px;margin:0 0 16px}h3{margin:0 0 10px}.lead{font-size:18px;color:var(--muted);max-width:780px}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.stack{display:grid;gap:16px}.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.button,button{border:0;border-radius:15px;padding:11px 16px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#07101c;font-weight:850;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 32px rgba(158,232,216,.13)}.button.ghost,button.ghost{background:transparent;color:var(--accent);border:1px solid var(--line);box-shadow:none}.button.danger,button.danger{background:transparent;color:var(--danger);border:1px solid rgba(255,154,166,.5);box-shadow:none}.small{padding:7px 10px;border-radius:11px;font-size:13px}label{display:grid;gap:8px;color:var(--muted);font-weight:750}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:16px;background:#0d1425;color:var(--text);padding:12px 14px;font:inherit}textarea{resize:vertical}.flash{padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);margin-bottom:16px}.flash.error{background:rgba(255,154,166,.1);border-color:rgba(255,154,166,.35);color:#ffd0d5}.flash.success{background:rgba(159,245,189,.1);border-color:rgba(159,245,189,.35);color:#cfffe1}.tag{display:inline-flex;margin:3px 4px 3px 0;padding:5px 9px;border:1px solid var(--line);border-radius:999px;color:#dbe7ff;background:rgba(255,255,255,.045);font-size:12px}.entry{display:grid;gap:8px}.entry-title{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.date{color:var(--muted);font-size:13px}.core-wrap{position:relative;min-height:420px;overflow:hidden}.core-center{position:absolute;left:50%;top:50%;width:110px;height:110px;transform:translate(-50%,-50%);border-radius:999px;background:radial-gradient(circle at 30% 30%,#fff,var(--accent) 24%,#7b86ff 70%,#292f61);box-shadow:0 0 70px rgba(158,232,216,.45)}.spark{position:absolute;border-radius:999px;background:var(--accent);box-shadow:0 0 22px currentColor;color:var(--accent);opacity:.9}.chat{display:grid;gap:14px}.msg{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}.msg.user{background:rgba(158,232,216,.08)}.msg.assistant{background:rgba(184,167,255,.08)}.table{width:100%;border-collapse:collapse}.table td,.table th{padding:10px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;vertical-align:top}code{background:#222b43;padding:2px 6px;border-radius:7px}.footer{padding:24px min(4vw,42px);border-top:1px solid rgba(255,255,255,.08);color:var(--muted)}@media(max-width:850px){.hero,.grid,.grid.two{grid-template-columns:1fr}.topbar{align-items:flex-start;gap:10px;flex-direction:column}.core-wrap{min-height:330px}}


/* Echoesium Core visual refresh — closer to the reference: glossy glass core + quiet orbital traces */
.card.core-wrap{
  padding:0;
}
.core-wrap{
  position:relative;
  min-height:520px;
  overflow:hidden;
  isolation:isolate;
  border-radius:42px;
  background:
    radial-gradient(circle at 43% 43%,rgba(82,238,255,.18),transparent 19%),
    radial-gradient(circle at 57% 58%,rgba(122,79,255,.20),transparent 21%),
    radial-gradient(circle at 18% 12%,rgba(95,196,255,.09),transparent 30%),
    linear-gradient(150deg,#101d32 0%,#090f21 48%,#050817 100%);
  border:1px solid rgba(148,184,238,.20);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.035),
    inset 0 0 90px rgba(80,130,255,.055),
    0 24px 85px rgba(0,0,0,.38);
}
.core-wrap::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:520px;
  height:310px;
  transform:translate(-50%,-47%);
  border-radius:999px;
  background:
    radial-gradient(circle at 40% 45%,rgba(67,235,238,.30),transparent 27%),
    radial-gradient(circle at 62% 67%,rgba(111,65,255,.30),transparent 23%);
  filter:blur(34px);
  opacity:.72;
  pointer-events:none;
  z-index:0;
}
.core-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(186,214,255,.10);
  pointer-events:none;
  z-index:20;
}
.core-center{
  position:absolute;
  left:50%;
  top:51%;
  width:196px;
  height:196px;
  transform:translate(-50%,-50%);
  border-radius:999px;
  z-index:8;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 30% 25%,rgba(255,255,255,.98) 0 5%,rgba(255,255,255,.52) 6%,rgba(255,255,255,0) 16%),
    radial-gradient(circle at 33% 31%,rgba(190,255,246,.88) 0 17%,rgba(96,247,238,.55) 25%,rgba(0,0,0,0) 43%),
    radial-gradient(circle at 67% 76%,rgba(255,255,255,.78) 0 5%,rgba(204,168,255,.54) 10%,rgba(0,0,0,0) 24%),
    radial-gradient(circle at 64% 58%,rgba(70,55,255,.88) 0 23%,rgba(74,77,255,.72) 37%,rgba(0,0,0,0) 56%),
    radial-gradient(circle at 36% 37%,rgba(68,241,232,.96) 0 36%,rgba(33,156,242,.94) 56%,rgba(116,79,255,.96) 83%,rgba(35,31,94,.98) 100%);
  border:1px solid rgba(190,250,255,.72);
  box-shadow:
    0 0 11px rgba(184,255,255,.95),
    0 0 38px rgba(70,228,255,.58),
    0 0 78px rgba(70,228,255,.30),
    0 0 118px rgba(117,75,255,.34),
    inset 16px -22px 34px rgba(22,32,158,.38),
    inset -22px 28px 42px rgba(207,255,250,.16);
  animation:coreBreath 6.2s ease-in-out infinite;
}
.core-center::before{
  content:"";
  position:absolute;
  inset:8%;
  border-radius:inherit;
  background:
    radial-gradient(ellipse at 22% 18%,rgba(255,255,255,.52) 0 9%,rgba(255,255,255,0) 20%),
    radial-gradient(ellipse at 78% 84%,rgba(255,255,255,.38) 0 8%,rgba(255,255,255,0) 19%),
    linear-gradient(128deg,rgba(255,255,255,.20),rgba(255,255,255,0) 31%,rgba(0,0,0,.18) 72%,rgba(255,255,255,.10));
  mix-blend-mode:screen;
  opacity:.92;
  pointer-events:none;
}
.core-center::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  background:
    radial-gradient(circle at 50% 50%,rgba(255,255,255,0) 54%,rgba(158,249,255,.55) 79%,rgba(126,91,255,.70) 96%,rgba(255,255,255,.12) 100%);
  box-shadow:inset 0 0 24px rgba(255,255,255,.18);
  pointer-events:none;
}
.core-orbit{
  position:absolute;
  left:50%;
  top:51%;
  border-radius:999px;
  border:1px solid rgba(85,215,255,.18);
  transform:translate(-50%,-50%) rotate(var(--orbit-rot,0deg));
  box-shadow:0 0 18px rgba(78,210,255,.055), inset 0 0 10px rgba(88,215,255,.035);
  opacity:var(--orbit-opacity,.85);
  pointer-events:none;
  z-index:3;
}
.core-orbit::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  border:1px dotted rgba(117,240,255,.13);
  transform:rotate(11deg);
  opacity:.75;
}
.core-orbit-1{width:78%;height:24%;--orbit-rot:-8deg;--orbit-opacity:.90;border-color:rgba(88,219,255,.23)}
.core-orbit-2{width:86%;height:29%;--orbit-rot:13deg;--orbit-opacity:.82;border-color:rgba(75,163,255,.19)}
.core-orbit-3{width:71%;height:42%;--orbit-rot:-31deg;--orbit-opacity:.62;border-color:rgba(120,95,255,.17)}
.core-orbit-4{width:69%;height:31%;--orbit-rot:33deg;--orbit-opacity:.55;border-color:rgba(100,210,255,.15)}
.core-orbit-5{width:60%;height:55%;--orbit-rot:-54deg;--orbit-opacity:.34;border-color:rgba(124,100,255,.13)}
.core-light-dot{
  position:absolute;
  width:5px;
  height:5px;
  border-radius:999px;
  background:#77f3ff;
  box-shadow:0 0 9px #77f3ff,0 0 21px rgba(90,219,255,.45);
  z-index:6;
  opacity:.92;
  pointer-events:none;
}
.core-light-dot.dot-a{left:31%;top:43%}
.core-light-dot.dot-b{left:77%;top:39%}
.core-light-dot.dot-c{left:66%;top:68%;background:#a492ff;box-shadow:0 0 9px #a492ff,0 0 20px rgba(132,92,255,.45)}
.core-light-dot.dot-d{left:26%;top:56%}
.spark{
  position:absolute;
  display:block;
  border-radius:999px;
  z-index:9;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 29% 22%,rgba(255,255,255,.95) 0 7%,rgba(255,255,255,.34) 8%,rgba(255,255,255,0) 19%),
    radial-gradient(circle at 35% 34%,rgba(151,255,247,.88) 0 20%,rgba(39,210,239,.88) 38%,rgba(45,91,246,.90) 68%,rgba(117,66,235,.82) 100%);
  border:1px solid rgba(183,247,255,.65);
  color:#78f3ff;
  opacity:.94;
  box-shadow:
    0 0 8px rgba(168,255,255,.96),
    0 0 24px rgba(78,218,255,.56),
    0 0 45px rgba(105,82,255,.28),
    inset 5px -8px 12px rgba(63,66,230,.38),
    inset -5px 7px 12px rgba(255,255,255,.18);
  transition:transform .18s ease,filter .18s ease,box-shadow .18s ease;
  animation:sparkFloat 7.4s ease-in-out infinite;
}
.spark::before{
  content:"";
  position:absolute;
  inset:-42%;
  border-radius:999px;
  background:radial-gradient(circle,rgba(111,235,255,.34),rgba(111,235,255,0) 64%);
  z-index:-1;
}
.spark::after{
  content:"";
  position:absolute;
  left:20%;
  top:14%;
  width:31%;
  height:24%;
  border-radius:999px;
  background:rgba(255,255,255,.70);
  filter:blur(.45px);
}
.spark:nth-of-type(3n+1){
  background:
    radial-gradient(ellipse at 29% 22%,rgba(255,255,255,.95) 0 7%,rgba(255,255,255,.30) 8%,rgba(255,255,255,0) 19%),
    radial-gradient(circle at 34% 34%,rgba(169,255,249,.92) 0 19%,rgba(30,214,234,.88) 41%,rgba(34,105,244,.90) 72%,rgba(92,67,229,.80) 100%);
}
.spark:nth-of-type(3n+2){
  background:
    radial-gradient(ellipse at 29% 22%,rgba(255,255,255,.92) 0 7%,rgba(255,255,255,.28) 8%,rgba(255,255,255,0) 19%),
    radial-gradient(circle at 35% 35%,rgba(209,240,255,.86) 0 18%,rgba(75,132,255,.88) 43%,rgba(131,75,255,.90) 76%,rgba(62,38,140,.84) 100%);
  border-color:rgba(210,190,255,.66);
  color:#b9a6ff;
}
.spark:hover{
  transform:scale(1.12);
  filter:brightness(1.12) saturate(1.12);
  box-shadow:
    0 0 12px rgba(178,255,255,1),
    0 0 34px rgba(94,222,255,.68),
    0 0 66px rgba(145,102,255,.42),
    inset 5px -8px 12px rgba(63,66,230,.38),
    inset -5px 7px 12px rgba(255,255,255,.20);
}
.trace-spark{animation-delay:var(--spark-delay,0ms)}
@keyframes coreBreath{
  0%,100%{filter:saturate(1) brightness(1);transform:translate(-50%,-50%) scale(1)}
  50%{filter:saturate(1.12) brightness(1.055);transform:translate(-50%,-50%) scale(1.018)}
}
@keyframes sparkFloat{
  0%,100%{margin-top:0;filter:saturate(1)}
  50%{margin-top:-4px;filter:saturate(1.16)}
}
@media(max-width:850px){
  .core-wrap{min-height:390px;border-radius:34px}
  .core-center{width:154px;height:154px}
  .core-orbit-1{width:82%;height:24%}
  .core-orbit-2{width:91%;height:30%}
  .core-orbit-3{width:76%;height:42%}
}

/* Echo personality mode UI */
.echo-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px}
.status-pill,.mini-badge{display:inline-flex;align-items:center;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);padding:6px 10px;font-size:12px;font-weight:850;color:#dbe7ff;white-space:nowrap}
.status-pill.ok{border-color:rgba(159,245,189,.35);background:rgba(159,245,189,.10);color:#cfffe1}
.status-pill.warn{border-color:rgba(255,210,135,.34);background:rgba(255,210,135,.09);color:#ffe3b1}
.mini-badge{margin-left:8px;padding:3px 8px;font-size:11px;color:var(--muted)}
@media(max-width:850px){.echo-head{display:grid}.status-pill{width:max-content}}

/* ChatGPT-like Echo conversation layout */
.echo-page{
  width:min(920px,94vw);
  height:calc(100dvh - 58px);
  margin:0 auto;
  padding:16px 0 18px;
  display:flex;
}
.echo-page + .footer{display:none}
.echo-shell{
  width:100%;
  min-height:0;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:12px;
}
.echo-chat-top{
  padding:0 4px;
}
.echo-head.compact{
  margin-bottom:10px;
  align-items:center;
}
.echo-head.compact h1{
  margin:0 0 4px;
  font-size:clamp(25px,3.8vw,42px);
}
.echo-head.compact p{
  margin:0;
}
.echo-messages{
  min-height:0;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:10px 4px 18px;
  scroll-behavior:smooth;
}
.echo-messages .msg{
  width:fit-content;
  max-width:min(760px,86%);
  padding:14px 16px;
  border-radius:22px;
  overflow-wrap:anywhere;
}
.echo-messages .msg.user{
  align-self:flex-end;
  border-bottom-right-radius:7px;
  background:rgba(158,232,216,.12);
}
.echo-messages .msg.assistant{
  align-self:flex-start;
  border-bottom-left-radius:7px;
  background:rgba(184,167,255,.10);
}
.msg-meta{
  display:flex;
  gap:8px;
  align-items:center;
  margin-bottom:6px;
  color:#eaf2ff;
}
.msg-content{
  white-space:pre-wrap;
}

.msg-content .md-heading{
  display:block;
  white-space:normal;
  color:var(--text);
  font-weight:850;
  line-height:1.35;
}
.msg-content .md-heading-2{
  font-size:1.06rem;
  margin:9px 0 4px;
}
.msg-content .md-heading-3{
  font-size:.98rem;
  margin:7px 0 3px;
}
.msg-content .md-heading:first-child{
  margin-top:0;
}
.msg-content .md-quote,
.msg-content blockquote.md-quote{
  margin:10px 0;
  padding:11px 13px 11px 15px;
  border-left:3px solid rgba(158,232,216,.78);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(158,232,216,.10),rgba(184,167,255,.075));
  color:#dfeaff;
  white-space:normal;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
}
.msg-content .md-quote:first-child{
  margin-top:0;
}
.msg-content .md-quote:last-child{
  margin-bottom:0;
}
.msg-content blockquote.md-quote p{
  margin:0;
}
.msg-sources{
  margin:12px 0 0;
}
.echo-feedback{
  margin-top:12px;
}
.echo-empty{
  align-self:center;
  max-width:560px;
  margin:auto 0;
  text-align:center;
  color:var(--muted);
  padding:28px 18px;
}
.echo-empty h2{
  color:var(--text);
  margin-bottom:8px;
}
.echo-empty p{
  margin:0;
}
.echo-composer{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:end;
  padding:12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  background:rgba(13,20,37,.88);
  box-shadow:0 20px 60px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(16px);
}
.echo-composer textarea{
  min-height:46px;
  max-height:180px;
  resize:none;
  border:0;
  border-radius:18px;
  background:transparent;
  padding:12px 10px;
  outline:none;
}
.echo-composer textarea:focus{
  box-shadow:none;
}
.echo-composer button{
  min-height:46px;
  border-radius:18px;
  padding:0 18px;
}
@media(max-width:850px){
  .echo-page{
    width:min(100%,94vw);
    min-height:calc(100dvh - 104px);
    height:auto;
    padding:12px 0 14px;
  }
  .echo-head.compact{
    gap:8px;
  }
  .echo-messages .msg{
    max-width:92%;
  }
  .echo-composer{
    grid-template-columns:1fr;
    gap:8px;
  }
  .echo-composer button{
    width:100%;
  }
}

/* Echo async composer state */
.echo-composer button:disabled{
  opacity:.62;
  cursor:not-allowed;
}
.echo-messages .msg.pending{
  opacity:.92;
}
.echo-messages .msg.echo-loading{
  color:var(--muted);
}
.typing-dots{
  display:inline-flex;
  gap:5px;
  align-items:center;
  min-height:20px;
}
.typing-dots span{
  width:7px;
  height:7px;
  border-radius:999px;
  background:currentColor;
  opacity:.35;
  animation:echoTypingDot 1.15s ease-in-out infinite;
}
.typing-dots span:nth-child(2){animation-delay:.15s}
.typing-dots span:nth-child(3){animation-delay:.30s}
@keyframes echoTypingDot{
  0%,80%,100%{transform:translateY(0);opacity:.32}
  40%{transform:translateY(-4px);opacity:.92}
}


/* Site-wide Urbanist font */
html, body, button, input, textarea, select, .button {
  font-family:'Urbanist',ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
}


/* Admin panel */
.admin-shell h1{margin-bottom:8px}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(122px,1fr));gap:14px;margin:18px 0}
.admin-stat{padding:18px}
.admin-stat span{display:block;color:var(--muted);font-weight:800;font-size:13px;margin-bottom:6px}
.admin-stat strong{display:block;font-size:clamp(24px,3vw,38px);line-height:1;color:var(--text)}
.admin-section{margin-top:18px}
.admin-table-wrap{width:100%;overflow:auto;border-radius:18px;border:1px solid rgba(255,255,255,.06)}
.admin-table-wrap .table{min-width:1080px}
.admin-actions{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}
.admin-actions form{margin:0}
.admin-delete summary{cursor:pointer;color:var(--danger);font-weight:850;font-size:13px;padding:7px 0}
.admin-delete form{display:flex;gap:8px;align-items:center;margin-top:6px}
.admin-delete input{width:92px;padding:8px 10px;border-radius:11px}

.admin-subscribe-form{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.admin-subscribe-form input[type=date]{
  width:145px;
  padding:8px 10px;
  border-radius:11px;
}
@media(max-width:650px){.admin-subscribe-form{display:grid}.admin-subscribe-form input[type=date]{width:100%}}
@media(max-width:1100px){.admin-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:650px){.admin-stats{grid-template-columns:1fr 1fr}.admin-delete form{display:grid}.admin-delete input{width:100%}}


/* Admin-created Echo agents */
.inline-check{display:flex;align-items:center;gap:10px;color:var(--text)}
.inline-check input{width:auto}
.echo-agent-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.echo-agent-card{position:relative;overflow:hidden;min-height:230px;display:flex;flex-direction:column;gap:10px}
.echo-agent-card::before{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;border-radius:999px;background:radial-gradient(circle,rgba(158,232,216,.18),transparent 68%);pointer-events:none}
.echo-agent-icon{width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.echo-agent-card h2{margin:2px 0 0;font-size:25px}
.echo-agent-card p{flex:1}
@media(max-width:650px){.echo-agent-grid{grid-template-columns:1fr}}

/* Echo source writings */
.source-admin .source-add{
  margin-top:16px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.035);
}
.source-admin .source-add summary{
  cursor:pointer;
  font-weight:900;
  color:var(--text);
  margin-bottom:12px;
}
.source-form textarea[name="source_body"]{
  min-height:260px;
  font-family:'Urbanist',ui-sans-serif,system-ui,sans-serif;
  line-height:1.55;
}
.source-form input[type="number"]{
  max-width:180px;
}
.echo-agent-card .mini-badge{
  align-self:flex-start;
  margin-top:-2px;
}

/* User-facing landing page */
.landing-page{
  width:min(1180px,92vw);
  margin:0 auto;
  padding:44px 0 78px;
}
.landing-hero{
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr);
  gap:34px;
  align-items:center;
  min-height:calc(100dvh - 120px);
}
.landing-hero-copy{
  display:grid;
  gap:18px;
}
.eyebrow{
  width:max-content;
  max-width:100%;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 11px;
  border:1px solid rgba(158,232,216,.24);
  border-radius:999px;
  background:rgba(158,232,216,.08);
  color:#c8fff4;
  font-size:13px;
  font-weight:850;
  letter-spacing:.2px;
}
.landing-hero h1{
  max-width:880px;
  margin:0;
  font-size:clamp(46px,8vw,92px);
  letter-spacing:-2.5px;
}
.landing-lead{
  margin:0;
  max-width:720px;
  color:#dbe7ff;
  font-size:clamp(19px,2.1vw,25px);
  line-height:1.42;
  font-weight:650;
}
.landing-soft{
  margin:0;
  max-width:690px;
  color:var(--muted);
  font-size:17px;
}
.landing-actions{
  margin-top:6px;
}
.landing-mini-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:2px;
}
.landing-mini-row span{
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background:rgba(255,255,255,.045);
  color:#d7e4ff;
  font-size:13px;
  font-weight:800;
}
.landing-core-visual{
  min-height:560px;
}
.landing-core-note{
  position:absolute;
  left:28px;
  right:28px;
  bottom:25px;
  z-index:30;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(5,10,26,.48);
  backdrop-filter:blur(14px);
  color:#eff6ff;
  box-shadow:0 14px 42px rgba(0,0,0,.18);
}
.landing-core-note span{
  color:var(--muted);
  font-weight:700;
}
.landing-section{
  margin-top:34px;
}
.landing-intro-card{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:26px;
  align-items:center;
  padding:28px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:30px;
  background:linear-gradient(135deg,rgba(158,232,216,.08),rgba(184,167,255,.06));
  box-shadow:0 20px 70px rgba(0,0,0,.18);
}
.landing-intro-card h2,
.section-head h2,
.landing-split h2,
.landing-final h2{
  margin:12px 0 0;
  font-size:clamp(28px,4vw,48px);
  line-height:1.05;
  letter-spacing:-.8px;
}
.landing-intro-card p,
.landing-split p,
.landing-final p{
  margin:0;
  color:#cbd7ef;
  font-size:17px;
}
.landing-about-copy{
  display:grid;
  gap:12px;
}
.landing-about-copy p{
  margin:0;
}
.section-head{
  display:grid;
  gap:10px;
  max-width:780px;
  margin-bottom:18px;
}
.section-head.centered{
  margin-left:auto;
  margin-right:auto;
  text-align:center;
  justify-items:center;
}
.section-head h2{
  margin-top:0;
}
.section-head p{
  margin:0;
  font-size:17px;
}
.landing-grid{
  display:grid;
  gap:18px;
}
.landing-grid.three{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.landing-grid.two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.landing-card{
  position:relative;
  overflow:hidden;
  min-height:205px;
  padding:22px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:26px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  box-shadow:0 18px 62px rgba(0,0,0,.18);
}
.landing-card::before{
  content:"";
  position:absolute;
  inset:-70px -60px auto auto;
  width:150px;
  height:150px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(158,232,216,.16),transparent 68%);
  pointer-events:none;
}
.landing-card h3{
  margin:8px 0 9px;
  font-size:22px;
}
.landing-card p{
  margin:0;
  color:var(--muted);
}
.landing-echo-agents{
  padding:28px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:34px;
  background:radial-gradient(circle at 50% 0,rgba(158,232,216,.10),transparent 34%),rgba(255,255,255,.03);
}
.landing-echo-grid{
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
}
.landing-echo-card{
  min-height:260px;
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.026));
}
.landing-echo-card h3{
  margin:2px 0 0;
  font-size:24px;
  letter-spacing:-.2px;
}
.landing-echo-card p{
  flex:1;
}
.landing-echo-badges{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  align-items:center;
}
.landing-echo-more{
  display:flex;
  justify-content:center;
  margin-top:18px;
}
@media(max-width:560px){
  .landing-echo-agents{
    border-radius:22px;
    padding:20px;
  }
}
.card-no{
  display:inline-flex;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  border-radius:15px;
  background:linear-gradient(135deg,rgba(158,232,216,.22),rgba(184,167,255,.18));
  color:#eaf4ff;
  font-weight:900;
}
.landing-split{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:center;
  padding:30px;
  border-radius:34px;
  background:radial-gradient(circle at 0 50%,rgba(184,167,255,.11),transparent 34%),rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.09);
}
.landing-quote-card{
  padding:28px;
  border-radius:28px;
  background:linear-gradient(135deg,rgba(158,232,216,.16),rgba(184,167,255,.10));
  border:1px solid rgba(255,255,255,.12);
}
.landing-quote-card p{
  margin:0;
  color:#f0f6ff;
  font-size:clamp(22px,3vw,34px);
  line-height:1.2;
  font-weight:850;
  letter-spacing:-.4px;
}
.landing-final{
  margin-top:38px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:32px;
}
.landing-final p{
  max-width:680px;
  margin-top:12px;
}
@media(max-width:950px){
  .landing-hero,
  .landing-intro-card,
  .landing-split,
  .landing-grid.three,
  .landing-grid.two{
    grid-template-columns:1fr;
  }
  .landing-hero{
    min-height:auto;
    padding-top:24px;
  }
  .landing-core-visual{
    min-height:430px;
  }
  .landing-final{
    display:grid;
  }
}
@media(max-width:560px){
  .landing-page{
    padding-top:24px;
  }
  .landing-hero h1{
    letter-spacing:-1.4px;
  }
  .landing-intro-card,
  .landing-split,
  .landing-final,
  .landing-card{
    border-radius:22px;
    padding:20px;
  }
  .landing-core-note{
    left:16px;
    right:16px;
    bottom:16px;
    display:grid;
    gap:4px;
  }
}

.square-place-library span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.30),rgba(255,255,255,0) 30%),radial-gradient(circle,rgba(122,255,214,.15),rgba(119,91,255,.08) 70%)}
.square-place-quiet span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.25),rgba(255,255,255,0) 32%),radial-gradient(circle,rgba(255,255,255,.11),rgba(77,103,145,.08) 70%)}
.echo-intent{
  position:absolute;
  left:50%;
  top:-30px;
  transform:translateX(-50%) translateY(4px);
  max-width:168px;
  padding:5px 8px;
  border-radius:999px;
  background:rgba(7,10,23,.74);
  border:1px solid rgba(255,255,255,.13);
  color:rgba(239,251,255,.90);
  font-size:10.5px;
  font-weight:850;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  box-shadow:0 10px 28px rgba(0,0,0,.20);
  backdrop-filter:blur(14px);
  opacity:0;
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
}
.echo-walker:hover .echo-intent,
.echo-walker:focus-visible .echo-intent,
.echo-walker.selected .echo-intent,
.echo-walker.is-speaking .echo-intent{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
.echo-walker.is-moving:not(.is-speaking):not(.is-resting) .echo-avatar{animation:echoWalkBob 1.14s ease-in-out infinite}
.echo-walker.is-thinking .echo-avatar{animation:echoThinkPulse 2.65s ease-in-out infinite}
.echo-walker.is-reading .echo-avatar{animation:echoReadGlow 2.25s ease-in-out infinite}
.echo-walker.is-resting .echo-avatar{animation:echoRestBreathe 3.2s ease-in-out infinite}
.echo-walker.is-speaking .echo-avatar{animation:echoSpeakPulse .82s ease-in-out infinite}
.echo-walker.is-speaking .echo-name-tag{border-color:rgba(139,238,255,.28);box-shadow:0 0 22px rgba(93,229,255,.12)}
.echo-walker.is-moving .echo-shadow{animation:echoShadowWalk 1.14s ease-in-out infinite}
.echo-walker.facing-left .echo-avatar{filter:saturate(1.05) brightness(1.03)}
.echo-live-intent{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:4px 0 12px;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(236,249,255,.90);
  font-size:13px;
  font-weight:850;
}
.echo-live-intent span{
  width:9px;
  height:9px;
  border-radius:999px;
  background:rgba(112,235,255,.86);
  box-shadow:0 0 16px rgba(112,235,255,.72);
  animation:echoLiveDot 1.4s ease-in-out infinite;
}
/* Echo Meydanı avatar hizalama düzeltmesi: avatarlar absolute + left:50% ile
   konumlandığı için animasyon transform değerlerinde translateX(-50%) korunmalı.
   Aksi halde animasyon başlayınca saydam arka plan/ikon sağa kaymış görünür. */
@keyframes echoWalkBob{
  0%,100%{transform:translateX(-50%) translateY(0) rotate(-1deg)}
  50%{transform:translateX(-50%) translateY(-5px) rotate(1deg)}
}
@keyframes echoThinkPulse{
  0%,100%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 0 18px rgba(94,227,255,.42),0 0 42px rgba(119,88,255,.22),inset 0 0 14px rgba(255,255,255,.18)}
  50%{transform:translateX(-50%) translateY(-2px) scale(1.045);box-shadow:0 0 28px rgba(194,164,255,.46),0 0 64px rgba(93,228,255,.22),inset 0 0 18px rgba(255,255,255,.22)}
}
@keyframes echoReadGlow{
  0%,100%{transform:translateX(-50%) translateY(0);filter:brightness(1)}
  50%{transform:translateX(-50%) translateY(-3px);filter:brightness(1.22)}
}
@keyframes echoRestBreathe{
  0%,100%{transform:translateX(-50%) scale(.98);opacity:.88}
  50%{transform:translateX(-50%) scale(1.025);opacity:1}
}
@keyframes echoSpeakPulse{
  0%,100%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 0 22px rgba(255,255,255,.52),0 0 56px rgba(91,229,255,.42),inset 0 0 14px rgba(255,255,255,.22)}
  50%{transform:translateX(-50%) translateY(-4px) scale(1.06);box-shadow:0 0 34px rgba(255,255,255,.72),0 0 76px rgba(132,91,255,.42),inset 0 0 18px rgba(255,255,255,.26)}
}
@keyframes echoShadowWalk{
  0%,100%{transform:translateX(-50%) scaleX(1);opacity:.9}
  50%{transform:translateX(-50%) scaleX(1.22);opacity:.65}
}
@keyframes echoLiveDot{
  0%,100%{transform:scale(.82);opacity:.72}
  50%{transform:scale(1.18);opacity:1}
}
@media(max-width:680px){
  .square-place b{display:none}
  .square-place span{width:28px;height:28px}
  .echo-intent{max-width:132px;font-size:9.5px;top:-26px}
}

/* Echo Meydanı: otomatik sohbet ve geçmiş */
.square-auto-status{
  margin:10px 6px 0;
  padding:9px 11px;
  border-radius:16px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
}
.echo-panel-memory{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(120,235,255,.07);
  border:1px solid rgba(120,235,255,.12);
  font-weight:800;
}
.echo-square-history-preview{
  margin-top:18px;
}
.echo-square-history-list{
  display:grid;
  gap:14px;
  margin-top:16px;
}
.echo-square-chat-card{
  overflow:hidden;
  border-color:rgba(136,235,255,.12);
  background:
    radial-gradient(circle at 8% 0%,rgba(91,224,255,.08),rgba(0,0,0,0) 30%),
    radial-gradient(circle at 90% 20%,rgba(139,98,255,.09),rgba(0,0,0,0) 35%),
    rgba(255,255,255,.045);
}
.echo-square-chat-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:12px;
}
.echo-square-chat-head h2{
  margin:8px 0 6px;
}

.echo-square-group-badge{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:8px;
}
.echo-square-group-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:5px 10px 5px 6px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#dbe7ff;
  font-size:12px;
  font-weight:800;
  line-height:1;
}
.echo-square-inline-avatar,
.echo-square-msg-avatar{
  width:26px;
  height:26px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  flex:0 0 auto;
  font-size:14px;
}
.square-msg-meta{
  gap:10px;
  align-items:flex-start;
}
.square-msg-meta-text{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.square-msg-meta .mini-badge{
  margin-left:0;
}
.echo-square-chat-log{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.square-dialogue-msg{
  max-width:880px;
  background:rgba(8,12,28,.42);
}
.square-dialogue-msg:nth-child(even){
  margin-left:auto;
  background:rgba(22,18,46,.48);
}
@media(max-width:680px){
  .echo-square-chat-head{display:grid}
  .square-dialogue-msg,.square-dialogue-msg:nth-child(even){margin-left:0;max-width:100%}
}
.square-auto-box{
  margin:12px 6px 2px;
  padding:10px 12px;
  border-radius:18px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(140,220,255,.13);
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:12px;
  text-align:right;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.square-auto-box b{
  display:none;
}
.square-auto-box span,
.square-auto-status{
  color:rgba(214,224,255,.78);
  font-size:.88rem;
  line-height:1.45;
}
.square-auto-box span{
  margin-left:auto;
}
@media(max-width:680px){
  .square-auto-box{display:flex;gap:5px}
}

/* Echo Meydanı: manuel sohbet başlatma */
.square-manual-box{
  margin:10px 6px 2px;
  padding:12px;
  border-radius:20px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(156,236,255,.15);
  display:grid;
  gap:10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 18px 44px rgba(0,0,0,.10);
}
.square-manual-box b{
  display:block;
  margin-bottom:3px;
  font-size:.92rem;
  color:rgba(245,248,255,.94);
}
.square-manual-box span,
.echo-panel-manual{
  color:rgba(214,224,255,.78);
  font-size:.88rem;
  line-height:1.45;
}
.square-manual-chips{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  min-height:32px;
  align-items:center;
}
.square-manual-chip{
  border:1px solid rgba(138,235,255,.22);
  background:rgba(8,12,28,.48);
  color:rgba(239,251,255,.92);
  border-radius:999px;
  padding:7px 10px;
  font:inherit;
  font-size:.82rem;
  font-weight:850;
  cursor:pointer;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.square-manual-chip:hover,.square-manual-chip:focus-visible{
  border-color:rgba(205,249,255,.45);
  outline:none;
}
.square-manual-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.square-admin-question-box{
  margin:10px 6px 2px;
  padding:12px;
  border-radius:20px;
  background:linear-gradient(135deg,rgba(123,92,255,.13),rgba(91,224,255,.07));
  border:1px solid rgba(188,174,255,.20);
  display:grid;
  gap:10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 18px 44px rgba(0,0,0,.12);
}
.square-admin-question-box b{
  display:block;
  margin-bottom:3px;
  font-size:.92rem;
  color:rgba(245,248,255,.96);
}
.square-admin-question-box span{
  color:rgba(214,224,255,.78);
  font-size:.88rem;
  line-height:1.45;
}
.square-admin-question-box textarea{
  width:100%;
  min-height:76px;
  resize:vertical;
  border-radius:16px;
  border:1px solid rgba(180,205,255,.16);
  background:rgba(8,12,28,.42);
  color:rgba(246,250,255,.96);
  padding:10px 12px;
  font:inherit;
  outline:none;
}
.square-admin-question-box textarea:focus{
  border-color:rgba(190,244,255,.42);
  box-shadow:0 0 0 4px rgba(120,235,255,.10);
}
.square-admin-question-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.echo-walker.manual-selected .echo-avatar{
  border-color:rgba(255,255,255,.92);
  box-shadow:0 0 0 4px rgba(112,235,255,.18),0 0 28px rgba(255,255,255,.68),0 0 74px rgba(112,235,255,.48),inset 0 0 14px rgba(255,255,255,.24);
}
.echo-walker.manual-selected .echo-name-tag{
  border-color:rgba(139,238,255,.32);
  background:rgba(9,18,38,.78);
}
.echo-walker.manual-disabled{
  cursor:pointer;
  opacity:.78;
}
.echo-walker.manual-disabled .echo-avatar{
  filter:saturate(.78) brightness(.92);
}
@media(max-width:680px){
  .square-manual-box,.square-admin-question-box{margin:10px 2px 2px;padding:10px;border-radius:18px}
  .square-manual-actions .button,.square-admin-question-actions .button{width:100%}
}

.square-place-workshop span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.30),rgba(255,255,255,0) 30%),radial-gradient(circle,rgba(158,232,216,.18),rgba(184,167,255,.09) 68%)}
.square-place-monument span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.30),rgba(255,255,255,0) 30%),radial-gradient(circle,rgba(255,230,166,.16),rgba(124,100,255,.09) 70%)}
.square-place-dream span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.30),rgba(255,255,255,0) 30%),radial-gradient(circle,rgba(184,167,255,.18),rgba(74,224,255,.08) 68%)}
.square-place-migration span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.30),rgba(255,255,255,0) 30%),radial-gradient(circle,rgba(87,236,255,.18),rgba(255,255,255,.04) 70%)}
.square-place-archive span{background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.25),rgba(255,255,255,0) 32%),radial-gradient(circle,rgba(255,255,255,.11),rgba(77,103,145,.08) 70%)}

.thought-archive-details{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
}
.thought-archive-details summary{
  cursor:pointer;
  font-weight:800;
  color:rgba(235,242,255,.92);
}
.thought-archive-details pre{
  margin:10px 0 0;
  white-space:pre-wrap;
  word-break:break-word;
  font:inherit;
  color:rgba(235,242,255,.82);
}

.memory-curation-box{
  margin-top:14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:12px;
  background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
}
.memory-curation-box summary{
  cursor:pointer;
  font-weight:700;
  color:var(--text);
  list-style:none;
}
.memory-curation-box summary::-webkit-details-marker{display:none}
.memory-curation-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
  margin-top:12px;
}
.memory-curation-item{
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding:12px;
  background:rgba(10,18,32,.42);
}
.memory-curation-top{
  display:flex;
  justify-content:space-between;
  gap:8px;
  align-items:center;
  margin-bottom:8px;
}
.memory-curation-item b{display:block;margin-bottom:6px}
.memory-curation-item p{margin:6px 0 0}
.memory-curation-active_memory{box-shadow:inset 0 0 0 1px rgba(74,224,255,.10)}
.memory-curation-monument{box-shadow:inset 0 0 0 1px rgba(255,213,128,.13)}
.memory-curation-waiting{box-shadow:inset 0 0 0 1px rgba(184,167,255,.12)}
.memory-curation-archive{opacity:.88}

.memory-curation-card-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:12px;
}
.memory-curation-page .lead{max-width:780px}
.memory-curation-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  margin:16px 0;
}
.memory-curation-stat{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  text-decoration:none;
  color:inherit;
  min-height:76px;
}
.memory-curation-stat span{color:var(--muted);font-weight:700}
.memory-curation-stat b{font-size:28px;line-height:1}
.memory-curation-stat.is-active{
  border-color:rgba(126,231,255,.28);
  box-shadow:0 0 0 1px rgba(126,231,255,.12),0 18px 45px rgba(0,0,0,.18);
}
.memory-curation-list{display:grid;gap:14px;margin-top:14px}
.memory-curation-row{position:relative;overflow:hidden}
.memory-curation-row::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:rgba(255,255,255,.16);
}
.memory-curation-row-head{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
}
.memory-curation-row-head h2{margin:8px 0 4px}
.memory-curation-source{
  margin-top:12px;
  padding:10px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
}
.memory-curation-source b{display:block;margin-bottom:4px}
.memory-curation-source span{display:block;color:var(--muted);font-size:14px}
.memory-curation-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:12px;
}
.memory-curation-actions input[type="text"]{
  min-width:220px;
  flex:1 1 220px;
}
.memory-curation-row.memory-curation-monument::before{background:rgba(255,213,128,.55)}
.memory-curation-row.memory-curation-active_memory::before{background:rgba(74,224,255,.52)}
.memory-curation-row.memory-curation-waiting::before{background:rgba(184,167,255,.50)}
.memory-curation-row.memory-curation-archive::before{background:rgba(255,255,255,.22)}
@media (max-width:720px){
  .memory-curation-row-head{display:block}
  .memory-curation-actions input[type="text"]{min-width:100%}
}

/* Yankı Halkası / Anlam Soyağacı MVP */
.resonance-details{
  margin-top:10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.035);
  overflow:hidden;
}
.resonance-details summary{
  cursor:pointer;
  list-style:none;
  padding:10px 12px;
  font-weight:800;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.resonance-details summary::-webkit-details-marker{display:none}
.resonance-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  padding:0 12px 12px;
}
.resonance-grid>div{
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:10px;
  background:rgba(10,12,24,.22);
}
.resonance-grid b{
  display:block;
  margin-bottom:5px;
  color:var(--text);
}
.resonance-grid p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}

/* İç Yankılar / Yankı Çağırma Motoru MVP-2 */
.resonance-recall-details{
  margin:10px 0 0;
  border:1px solid rgba(126,231,255,.14);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(126,231,255,.055),rgba(255,255,255,.025));
  overflow:hidden;
}
.resonance-recall-details summary{
  cursor:pointer;
  list-style:none;
  padding:9px 11px;
  font-weight:800;
  color:rgba(235,242,255,.94);
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.resonance-recall-details summary::-webkit-details-marker{display:none}
.resonance-recall-list{
  display:grid;
  gap:8px;
  padding:0 11px 11px;
}
.resonance-recall-item{
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:10px;
  background:rgba(10,18,32,.32);
}
.resonance-recall-item b{display:block;margin-bottom:4px;color:var(--text)}
.resonance-recall-item p{margin:5px 0 0;font-size:14px;line-height:1.45}

/* Küresel Bilinç Sahnesi / GNW esinli MVP-3 */
.workspace-ignition-details{
  margin:10px 0 0;
  border:1px solid rgba(190,160,255,.18);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(190,160,255,.07),rgba(126,231,255,.035));
  overflow:hidden;
}
.workspace-ignition-details summary{
  cursor:pointer;
  list-style:none;
  padding:10px 12px;
  font-weight:900;
  color:rgba(242,238,255,.96);
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.workspace-ignition-details summary::-webkit-details-marker{display:none}
.workspace-ignition-body{padding:0 12px 12px;display:grid;gap:10px}
.workspace-ignition-main,
.workspace-broadcasts,
.workspace-candidates{
  border:1px solid rgba(255,255,255,.09);
  border-radius:16px;
  padding:10px;
  background:rgba(12,12,28,.30);
}
.workspace-ignition-main b,
.workspace-broadcasts b,
.workspace-candidate b{display:block;color:var(--text);margin-bottom:5px}
.workspace-ignition-main p,
.workspace-candidate p{margin:5px 0 0;font-size:14px;line-height:1.45}
.workspace-chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.workspace-candidates summary{cursor:pointer;list-style:none;font-weight:800;color:var(--text);padding:0}
.workspace-candidates summary::-webkit-details-marker{display:none}
.workspace-candidate-list{display:grid;gap:8px;margin-top:10px}
.workspace-candidate{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:9px;background:rgba(255,255,255,.025)}
.workspace-candidate.selected{border-color:rgba(190,160,255,.32);background:rgba(190,160,255,.07)}

/* Çelişki ve Geri Dönüş Motoru / MVP-4 */
.contradiction-review-details{
  margin:10px 0 0;
  border:1px solid rgba(255,188,120,.20);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,188,120,.075),rgba(255,255,255,.025));
  overflow:hidden;
}
.contradiction-review-details summary{
  cursor:pointer;
  list-style:none;
  padding:10px 12px;
  font-weight:900;
  color:rgba(255,246,232,.98);
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.contradiction-review-details summary::-webkit-details-marker{display:none}
.contradiction-review-body{padding:0 12px 12px;display:grid;gap:9px}
.contradiction-review-item{
  border:1px solid rgba(255,255,255,.09);
  border-radius:16px;
  padding:10px;
  background:rgba(28,18,10,.28);
}
.contradiction-review-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:5px}
.contradiction-review-head b{color:var(--text)}
.contradiction-review-item p{margin:5px 0 0;font-size:14px;line-height:1.45}

/* Hafıza Revizyonu ve Benlik Tutarlılığı Motoru / MVP-5 */
.memory-revision-details{
  margin:10px 0 0;
  border:1px solid rgba(156,220,180,.22);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(156,220,180,.075),rgba(255,255,255,.025));
  overflow:hidden;
}
.memory-revision-details summary{
  cursor:pointer;
  list-style:none;
  padding:10px 12px;
  font-weight:900;
  color:rgba(235,255,243,.98);
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.memory-revision-details summary::-webkit-details-marker{display:none}
.memory-revision-body{padding:0 12px 12px;display:grid;gap:9px}
.memory-revision-item{
  border:1px solid rgba(255,255,255,.09);
  border-radius:16px;
  padding:10px;
  background:rgba(9,28,18,.26);
}
.memory-revision-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:5px}
.memory-revision-head b{color:var(--text)}
.memory-revision-item p{margin:5px 0 0;font-size:14px;line-height:1.45}
.memory-revision-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px;align-items:center}
.memory-revision-actions input[type="text"]{min-width:220px;flex:1;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--text);padding:8px 10px}
.memory-revision-applied,.memory-revision-archived{opacity:.86}
.memory-revision-rejected{opacity:.62}

.memory-revision-item .mini-badge{white-space:nowrap}
.memory-revision-applied,.memory-revision-archived{border-color:rgba(120,220,170,.28);background:rgba(120,220,170,.06)}
.memory-revision-held{border-color:rgba(250,204,21,.28);background:rgba(250,204,21,.06)}


/* Echo image avatars */
.echo-agent-icon.has-image,
.echo-agent-admin-avatar.has-image,
.echo-avatar-form-preview.has-image,
.echo-avatar.has-image,
.echo-square-panel .echo-panel-emoji.has-image,
.square-manual-chip-avatar.has-image,
.echo-square-inline-avatar.has-image,
.echo-square-msg-avatar.has-image{
  overflow:hidden;
  font-size:0;
  padding:0;
}
.echo-agent-icon img,
.echo-agent-admin-avatar img,
.echo-avatar-form-preview img,
.echo-avatar img,
.echo-square-panel .echo-panel-emoji img,
.square-manual-chip-avatar img,
.echo-square-inline-avatar img,
.echo-square-msg-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:inherit;
}
.echo-avatar.has-image,
.echo-square-panel .echo-panel-emoji.has-image,
.echo-agent-icon.has-image,
.echo-avatar-form-preview.has-image{
  background:rgba(255,255,255,.08);
}
.echo-admin-agent-cell{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:190px;
}
.echo-agent-admin-avatar{
  width:38px;
  height:38px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  flex:0 0 auto;
}
.echo-avatar-form-row{
  display:grid;
  grid-template-columns:96px minmax(0,1fr);
  gap:16px;
  align-items:start;
}
.echo-avatar-form-preview{
  width:82px;
  height:82px;
  border-radius:26px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:42px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.square-manual-chip{
  display:inline-flex;
  align-items:center;
  gap:7px;
}
.square-manual-chip-avatar{
  width:22px;
  height:22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  font-size:14px;
  flex:0 0 auto;
}
@media(max-width:720px){
  .echo-avatar-form-row{grid-template-columns:1fr}
  .echo-avatar-form-preview{width:74px;height:74px}
}

/* Echo Meydanı: kullanıcı başına meydan katılımcısı seçimi */
.echo-square-select-launcher{margin-bottom:18px;display:flex;justify-content:flex-end}
.echo-square-top-actions{gap:12px;align-items:stretch;flex-wrap:wrap}
.echo-square-select-open-button{width:min(420px,100%);display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;border:1px solid rgba(255,255,255,.12);border-radius:22px;background:linear-gradient(135deg,rgba(114,236,255,.10),rgba(184,167,255,.08));color:inherit;padding:13px 14px;cursor:pointer;box-shadow:0 16px 38px rgba(0,0,0,.18);transition:transform .16s ease,border-color .16s ease,background .16s ease}
.echo-square-dream-open-button{width:min(330px,100%);background:linear-gradient(135deg,rgba(184,167,255,.12),rgba(255,216,124,.08))}
.echo-square-select-open-button:hover{transform:translateY(-1px);border-color:rgba(114,236,255,.36);background:linear-gradient(135deg,rgba(114,236,255,.15),rgba(184,167,255,.11))}
.echo-square-dream-open-button:hover{border-color:rgba(255,216,124,.34);background:linear-gradient(135deg,rgba(184,167,255,.17),rgba(255,216,124,.12))}
.echo-square-select-open-copy{display:grid;gap:3px;min-width:0}
.echo-square-select-open-copy b{font-size:15px;line-height:1.25}
.echo-square-select-open-copy small{font-size:12px;line-height:1.35;color:rgba(229,250,255,.72);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
body.echo-square-select-modal-open{overflow:hidden}
.echo-square-select-modal[hidden]{display:none}
.echo-square-select-modal{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:20px}
.echo-square-select-backdrop{position:absolute;inset:0;background:rgba(3,8,18,.72);backdrop-filter:blur(12px)}
.echo-square-select-dialog{position:relative;z-index:1;width:min(860px,100%);max-height:min(82vh,760px);overflow:auto;border:1px solid rgba(255,255,255,.14);border-radius:28px;background:linear-gradient(135deg,rgba(15,29,52,.98),rgba(22,18,44,.98));box-shadow:0 30px 90px rgba(0,0,0,.52);padding:20px}
.echo-square-select-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.echo-square-select-modal-head h2{margin:4px 0 6px}
.echo-square-select-modal-head .mini-badge{display:inline-flex;margin-top:4px}
.echo-square-select-close{width:38px;height:38px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.07);color:rgba(229,250,255,.9);font-size:24px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:transform .16s ease,border-color .16s ease,background .16s ease}
.echo-square-select-close:hover{transform:translateY(-1px);border-color:rgba(114,236,255,.35);background:rgba(255,255,255,.10)}
.echo-square-select-form{display:grid;gap:14px}
.echo-square-select-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.echo-square-select-empty{grid-column:1/-1;margin:0}
.echo-square-select-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;padding:12px;border:1px solid rgba(255,255,255,.10);border-radius:20px;background:rgba(255,255,255,.045);cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease;position:relative}
.echo-square-select-card:hover{transform:translateY(-1px);border-color:rgba(114,236,255,.28);background:rgba(255,255,255,.065)}
.echo-square-select-card.is-selected{border-color:rgba(114,236,255,.48);background:linear-gradient(135deg,rgba(114,236,255,.13),rgba(184,167,255,.09))}
.echo-square-select-card input{position:absolute;opacity:0;pointer-events:none}
.echo-square-select-card.is-disabled{opacity:.55;cursor:not-allowed}
.echo-square-select-avatar{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;font-size:24px;background:rgba(255,255,255,.08);box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);overflow:hidden}
.echo-square-select-avatar.has-image img{width:100%;height:100%;object-fit:cover;display:block}
.echo-square-select-card-text{display:grid;gap:3px;min-width:0}
.echo-square-select-card-text b{font-size:15px}
.echo-square-select-card-text small{color:rgba(229,250,255,.72);line-height:1.35}
.echo-square-select-card-text em{font-style:normal;font-size:12px;color:rgba(229,250,255,.55)}
.echo-square-select-actions{display:flex;align-items:center;gap:12px;justify-content:flex-start;flex-wrap:wrap}
.echo-square-select-actions .muted{margin-left:auto;max-width:360px;font-size:12px}
.echo-square-dream-dialog{width:min(920px,100%)}
.echo-square-dream-list{display:grid;gap:12px}
.echo-square-dream-card{display:grid;grid-template-columns:auto 1fr;gap:13px;padding:14px;border:1px solid rgba(255,255,255,.10);border-radius:22px;background:rgba(255,255,255,.045)}
.echo-square-dream-avatar{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;font-size:24px;background:linear-gradient(135deg,rgba(184,167,255,.16),rgba(114,236,255,.10));box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);overflow:hidden;flex:0 0 auto}
.echo-square-dream-avatar.has-image img{width:100%;height:100%;object-fit:cover;display:block}
.echo-square-dream-body{display:grid;gap:7px;min-width:0}
.echo-square-dream-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:rgba(229,250,255,.72);font-size:12px}
.echo-square-dream-meta b{font-size:14px;color:rgba(248,252,255,.94)}
.echo-square-dream-body h3{margin:0;font-size:16px;line-height:1.3}
.echo-square-dream-body p{margin:0;white-space:pre-wrap;color:rgba(229,250,255,.78);line-height:1.55}
.echo-square-dream-body .button{justify-self:start;margin-top:2px}
.echo-square-dream-empty{padding:18px;border:1px dashed rgba(255,255,255,.14);border-radius:22px;background:rgba(255,255,255,.04)}
.echo-square-dream-empty p{margin:6px 0 0}
@media (max-width:760px){.echo-square-select-launcher{justify-content:stretch}.echo-square-top-actions{display:grid}.echo-square-select-open-button{width:100%}.echo-square-select-open-copy small{max-width:190px}.echo-square-select-modal{padding:12px;align-items:end}.echo-square-select-dialog{max-height:88vh;border-radius:24px;padding:16px}.echo-square-select-modal-head{gap:10px}.echo-square-select-grid{grid-template-columns:1fr}.echo-square-select-actions .button{width:100%}.echo-square-select-actions .muted{margin-left:0;max-width:none}.echo-square-dream-card{grid-template-columns:1fr}.echo-square-dream-avatar{width:44px;height:44px;border-radius:16px}}

/* Contact / ticket module */
.contact-shell .echo-head{align-items:flex-start;margin-bottom:14px}
.contact-history{margin-top:18px}
.contact-list{display:grid;gap:12px}
.ticket-card{border:1px solid rgba(255,255,255,.10);border-radius:20px;background:rgba(255,255,255,.045);padding:16px}
.ticket-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.ticket-meta .date{margin-left:auto}
.ticket-body{white-space:pre-wrap;color:#dbe7ff;margin:8px 0 0}
.ticket-note{margin-top:12px;padding:12px;border-radius:16px;border:1px solid rgba(158,232,216,.22);background:rgba(158,232,216,.08)}
.ticket-note p{white-space:pre-wrap;margin:6px 0 0;color:#dbe7ff}
.ticket-admin-form{display:grid;gap:8px;min-width:260px}
.ticket-admin-form textarea{min-height:74px}
.ticket-row-body{max-width:420px}
.ticket-row-body p{margin:6px 0 0}
@media(max-width:760px){.ticket-meta .date{margin-left:0}.ticket-admin-form{min-width:220px}}

/* Subscription page */
/* Gemini Live sesli mod */
.voice-live-panel{margin:16px 0;background:linear-gradient(135deg,rgba(116,91,255,.16),rgba(72,201,176,.10));border:1px solid rgba(255,255,255,.12)}
.voice-live-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.voice-live-head h2{margin:.2rem 0 .25rem;font-size:1.15rem}
.voice-live-actions{display:flex;gap:10px;flex-wrap:wrap}
.voice-live-status{margin-top:12px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.08);font-size:.92rem;color:rgba(255,255,255,.84)}
.voice-live-transcript{margin-top:12px;max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:8px}
.voice-line{padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.08);line-height:1.45}
.voice-line b{display:inline-block;margin-right:8px;color:#fff}
.voice-line.user{align-self:flex-end;max-width:88%;background:rgba(116,91,255,.18)}
.voice-line.assistant{align-self:flex-start;max-width:92%;background:rgba(72,201,176,.12)}
@media (max-width:720px){.voice-live-head{align-items:flex-start}.voice-live-actions{width:100%}.voice-live-actions .button{flex:1}.voice-line.user,.voice-line.assistant{max-width:100%}}

/* Echo ses seçimi */
.voice-picker-form{
  margin:12px 0 0;
  padding:12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.06);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.voice-picker-form p{margin:.25rem 0 0}
.voice-picker-form label{margin:0;min-width:180px;flex:1;max-width:280px}
.voice-picker-form label span{display:block;margin-bottom:6px;color:rgba(255,255,255,.78);font-size:.88rem}
.voice-picker-form select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(18,18,28,.84);color:#fff}
@media (max-width:720px){.voice-picker-form{align-items:stretch}.voice-picker-form label{max-width:none}.voice-picker-form button{width:100%}}
.voice-picker-inline{margin:0}
.voice-picker-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.voice-test-status{width:100%;font-size:.9rem;min-height:1.25em;margin-top:-2px}
@media (max-width:720px){.voice-picker-actions{width:100%}.voice-picker-actions .button{flex:1}}

/* Çekirdek ayarları içinde gizlilik ve rıza kontrolleri */
.consent-inline{
  display:grid;
  gap:12px;
  margin:2px 0 4px;
  padding:16px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(255,255,255,.045);
}
.consent-inline h2{font-size:22px;margin:0 0 2px}
.consent-inline p{margin:0 0 2px}
.consent-inline label{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#dfe9ff;
  line-height:1.4;
}
.consent-inline input[type="checkbox"]{
  width:auto;
  margin-top:4px;
  flex:0 0 auto;
  accent-color:var(--accent);
}


/* Echoesium logo update — uploaded transparent logo is used in the top bar and favicon. */
.brand-logo{width:34px;height:34px;object-fit:contain;display:block;filter:drop-shadow(0 0 14px rgba(184,167,255,.34));}
@media(max-width:850px){.brand-logo{width:32px;height:32px}}

/* Echo Meydanı domain taşıma / eksik sahne stilleri düzeltmesi
   Bazı paketlerde ana sahne, nokta ve yürüyen Echo stilleri eksik kaldığı için
   POI etiketleri normal metin akışına düşüyor ve avatar görselleri devleşiyordu. */
.echo-square-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  gap:18px;
  align-items:stretch;
}
.echo-square-stage-card{overflow:hidden;min-width:0}
.echo-square-stage{
  position:relative;
  min-height:560px;
  overflow:hidden;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(circle at 50% 48%,rgba(115,235,255,.17),rgba(115,235,255,0) 18%),
    radial-gradient(circle at 20% 18%,rgba(184,167,255,.15),rgba(184,167,255,0) 32%),
    linear-gradient(135deg,rgba(10,25,45,.96),rgba(17,19,42,.97));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 24px 70px rgba(0,0,0,.28);
  isolation:isolate;
}
.square-sky,.square-orbit,.square-path{position:absolute;inset:0;pointer-events:none}
.square-sky{background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.08),transparent 28%);opacity:.9}
.square-orbit{border:1px solid rgba(128,229,255,.12);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);inset:auto;}
.square-orbit-a{width:54%;height:54%;box-shadow:0 0 45px rgba(117,229,255,.08)}
.square-orbit-b{width:78%;height:72%;border-color:rgba(184,167,255,.10);transform:translate(-50%,-50%) rotate(-10deg)}
.square-path{background:linear-gradient(90deg,transparent,rgba(255,255,255,.035),transparent);opacity:.45}
.square-path-a{transform:rotate(18deg)}
.square-path-b{transform:rotate(-24deg)}
.square-core{
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:132px;height:132px;
  border-radius:999px;
  display:grid;
  place-items:center;
  text-align:center;
  z-index:4;
  background:radial-gradient(circle at 35% 26%,rgba(255,255,255,.28),rgba(255,255,255,0) 34%),linear-gradient(135deg,rgba(114,236,255,.20),rgba(184,167,255,.15));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 0 36px rgba(91,229,255,.22),inset 0 0 22px rgba(255,255,255,.10);
}
.square-core span{font-size:15px;font-weight:900;color:rgba(236,249,255,.86)}
.square-core b{font-size:18px;color:#fff;margin-top:-34px}
.square-place{
  position:absolute;
  transform:translate(-50%,-50%);
  z-index:3;
  display:grid;
  justify-items:center;
  gap:6px;
  pointer-events:none;
  color:rgba(241,249,255,.92);
  font-weight:900;
  font-size:13px;
  text-shadow:0 2px 12px rgba(0,0,0,.45);
  white-space:nowrap;
}
.square-place span{
  width:38px;height:38px;border-radius:999px;
  display:block;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 0 24px rgba(114,236,255,.16),inset 0 0 14px rgba(255,255,255,.08);
}
.square-place-core{display:none}
.echo-walker{
  position:absolute;
  left:0;top:0;
  z-index:8;
  width:82px;
  height:104px;
  padding:0;
  border:0;
  background:transparent;
  color:inherit;
  cursor:pointer;
  transform:translate3d(var(--x,0px),var(--y,0px),0);
  transition:filter .18s ease;
  will-change:transform;
}
.echo-walker:hover{filter:brightness(1.12)}
.echo-avatar{
  position:absolute;
  left:50%;top:22px;
  transform:translateX(-50%);
  transform-origin:center center;
  width:58px;height:58px;
  border-radius:22px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:linear-gradient(135deg,rgba(114,236,255,.14),rgba(184,167,255,.14));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 0 22px rgba(114,236,255,.16),inset 0 0 12px rgba(255,255,255,.08);
  font-size:28px;
}
.echo-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.echo-shadow{
  position:absolute;
  left:50%;bottom:10px;
  width:54px;height:12px;
  transform:translateX(-50%);
  transform-origin:center center;
  border-radius:50%;
  background:rgba(0,0,0,.28);
  filter:blur(2px);
}
.echo-name-tag{
  position:absolute;
  left:50%;bottom:-3px;
  transform:translateX(-50%);
  max-width:96px;
  padding:4px 7px;
  border-radius:999px;
  background:rgba(5,9,20,.70);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(241,249,255,.90);
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.echo-walker.is-walking .echo-avatar{animation:echoWalkBob 2.8s ease-in-out infinite}
.echo-walker.is-thinking .echo-avatar{animation:echoThinkPulse 2.2s ease-in-out infinite}
.echo-walker.is-reading .echo-avatar{animation:echoReadGlow 2.3s ease-in-out infinite}
.echo-walker.is-resting .echo-avatar{animation:echoRestBreathe 2.8s ease-in-out infinite}
.echo-walker.is-speaking .echo-avatar{animation:echoSpeakPulse 1.45s ease-in-out infinite}
.echo-walker.manual-selected .echo-avatar{outline:2px solid rgba(114,236,255,.72);outline-offset:3px}
.echo-walker.manual-disabled{opacity:.58}
.square-hint{margin:12px 4px 0}
@media(max-width:980px){.echo-square-layout{grid-template-columns:1fr}.echo-square-stage{min-height:520px}.echo-square-panel{order:-1}}
@media(max-width:680px){.echo-square-stage{min-height:430px;border-radius:24px}.square-core{width:104px;height:104px}.square-core b{font-size:15px}.echo-walker{width:70px;height:92px}.echo-avatar{width:48px;height:48px;border-radius:18px}.echo-name-tag{font-size:10px;max-width:80px}}

/* Echo Meydanı hardfix v20260603: cache kırıldığında ve alan adı taşınırken sahne stilleri korunur. */
.echo-walker.is-moving .echo-avatar,.echo-walker.is-walking .echo-avatar{animation:echoWalkBob 2.8s ease-in-out infinite}

/* Echo Meydanı walker transform fix v20260603-2: JS'in verdiği --x/--y konumları kullanılır. */

/* Echo Meydanı sağ panel avatar görsel uyumu
   Seçili Echo panelinde resimli avatarların ham görsel gibi kartı doldurmasını engeller.
   Görsel artık Echo avatar kutusu gibi sabit, ortalı ve dengeli görünür. */
.echo-square-panel .echo-panel-emoji{
  width:112px;
  height:112px;
  max-width:42vw;
  max-height:42vw;
  margin:8px 0 2px;
  border-radius:30px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  overflow:hidden;
  font-size:54px;
  line-height:1;
  background:
    radial-gradient(circle at 34% 22%,rgba(255,255,255,.18),rgba(255,255,255,0) 34%),
    linear-gradient(135deg,rgba(114,236,255,.13),rgba(184,167,255,.13));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 18px 46px rgba(0,0,0,.20),inset 0 1px 0 rgba(255,255,255,.08);
}
.echo-square-panel .echo-panel-emoji.has-image{
  padding:0;
  background:rgba(255,255,255,.07);
}
.echo-square-panel .echo-panel-emoji img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
  border-radius:inherit;
}
@media(max-width:680px){
  .echo-square-panel .echo-panel-emoji{
    width:96px;
    height:96px;
    border-radius:26px;
    font-size:46px;
  }
}
