:root{
  --bg:#07080d;
  --bg2:#11131b;
  --panel:rgba(15,16,24,.84);
  --panel-2:rgba(21,16,28,.78);
  --line:rgba(216,176,107,.16);
  --gold:#d8b06b;
  --gold-soft:#f2d6a0;
  --ink:#efe7d6;
  --muted:#bba98b;
  --shadow:0 24px 90px rgba(0,0,0,.42);
  --coin-face-odd:url('assets/iching-coin-even.png');
  --coin-face-even:url('assets/iching-coin-odd.png');
}

*{box-sizing:border-box}
html,body{height:100%}

html::after{
  content:"";
  position:fixed;
  left:14px;
  bottom:14px;
  width:38px;
  height:38px;
  pointer-events:none;
  opacity:.12;
  z-index:0;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%23d8b06b' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 46h40M20 30l12 16 12-16M16 46l16-28 16 28M23 42l9-15 9 15'/%3E%3C/svg%3E");
  filter:drop-shadow(0 0 10px rgba(216,176,107,.18));
}
body{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  color:var(--ink);
  min-height:100vh;
  overflow-x:hidden;
  background:
    radial-gradient(circle at 50% 0, rgba(216,176,107,.09), transparent 18%),
    radial-gradient(circle at 18% 22%, rgba(40,79,74,.18), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(122,49,66,.18), transparent 24%),
    radial-gradient(circle at 50% 82%, rgba(216,176,107,.06), transparent 20%),
    linear-gradient(180deg, var(--bg), #0c0d13 40%, var(--bg2));
  background-repeat:no-repeat;
  background-attachment:fixed;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.32;
  background-image:
    radial-gradient(circle at 8% 18%, rgba(255,255,255,.7) 0 1px, transparent 2px),
    radial-gradient(circle at 18% 44%, rgba(255,255,255,.45) 0 1px, transparent 2px),
    radial-gradient(circle at 26% 26%, rgba(255,255,255,.6) 0 1px, transparent 2px),
    radial-gradient(circle at 36% 14%, rgba(255,255,255,.4) 0 1px, transparent 2px),
    radial-gradient(circle at 48% 22%, rgba(255,255,255,.6) 0 1px, transparent 2px),
    radial-gradient(circle at 65% 13%, rgba(255,255,255,.4) 0 1px, transparent 2px),
    radial-gradient(circle at 75% 18%, rgba(255,255,255,.55) 0 1px, transparent 2px),
    radial-gradient(circle at 88% 25%, rgba(255,255,255,.45) 0 1px, transparent 2px),
    radial-gradient(circle at 24% 82%, rgba(255,255,255,.5) 0 1px, transparent 2px),
    radial-gradient(circle at 84% 74%, rgba(255,255,255,.5) 0 1px, transparent 2px);
  background-repeat:no-repeat;
  background-size:100% 100%;
}
body::after{
  content:"乾 坤 震 巽 坎 離 艮 兌";
  position:fixed;
  right:18px;
  top:84px;
  color:rgba(216,176,107,.08);
  font-size:26px;
  letter-spacing:.28em;
  writing-mode:vertical-rl;
  pointer-events:none;
}

body.landing-intro-pending.landing-intro-active{
  overflow:hidden;
}
body.landing-intro-pending.landing-intro-active .landing-shell > *{
  opacity:0;
  transform:translateY(20px) scale(.992);
  filter:blur(10px);
}
body.landing-intro-active.landing-intro-ready .landing-shell > *{
  opacity:1;
  transform:none;
  filter:none;
  transition:
    opacity .95s ease,
    transform 1.1s cubic-bezier(.18,.7,.2,1),
    filter 1.1s ease;
}
body.landing-intro-active.landing-intro-ready .landing-shell > *:nth-child(1){transition-delay:.10s}
body.landing-intro-active.landing-intro-ready .landing-shell > *:nth-child(2){transition-delay:.18s}
body.landing-intro-active.landing-intro-ready .landing-shell > *:nth-child(3){transition-delay:.24s}
body.landing-intro-active.landing-intro-ready .landing-shell > *:nth-child(4){transition-delay:.30s}
body.landing-intro-active.landing-intro-ready .landing-shell > *:nth-child(5){transition-delay:.36s}
.landing-intro-veil{
  position:fixed;
  inset:0;
  z-index:30;
  pointer-events:none;
  opacity:1;
  background:
    radial-gradient(circle at 50% 44%, rgba(216,176,107,.07), transparent 24%),
    linear-gradient(180deg, rgba(3,4,7,.98) 0%, rgba(3,4,7,.88) 46%, rgba(3,4,7,.22) 100%);
  transition:opacity 1.28s ease, visibility 0s linear 1.28s;
}
.landing-intro-veil::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.14;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.05' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.85'/%3E%3C/svg%3E");
  background-size:220px 220px;
}
body.landing-intro-active.landing-intro-ready .landing-intro-veil{
  opacity:0;
  visibility:hidden;
}

.topbar{
  max-width:1180px;
  margin:0 auto;
  padding:18px 22px 8px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  position:relative;
  z-index:2;
}
.avatar-btn{
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(216,176,107,.24);
  background:linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.02));
  color:var(--gold-soft);
  cursor:pointer;
  font-size:17px;
  font-weight:700;
  box-shadow:0 18px 44px rgba(0,0,0,.42);
  position:absolute;
  left:22px;
  top:22px;
}
.brand-block{
  display:flex;
  align-items:center;
  gap:18px;
  min-width:0;
  padding-left:58px;
}
.brand-art{
  position:relative;
  width:96px;
  height:96px;
  flex:0 0 96px;
}
.mandala{
  position:absolute;
  inset:0;
  border-radius:50%;
  animation:slowspin 55s linear infinite;
  background:
    radial-gradient(circle at center, rgba(216,176,107,.24), rgba(216,176,107,.06) 16%, transparent 17%),
    radial-gradient(circle at center, transparent 0 24%, rgba(216,176,107,.09) 24.1% 24.5%, transparent 24.6%),
    radial-gradient(circle at center, transparent 0 38%, rgba(216,176,107,.10) 38.1% 38.4%, transparent 38.5%),
    radial-gradient(circle at center, transparent 0 52%, rgba(216,176,107,.08) 52.1% 52.35%, transparent 52.4%),
    radial-gradient(circle at center, transparent 0 66%, rgba(216,176,107,.06) 66.1% 66.3%, transparent 66.4%);
  filter:drop-shadow(0 0 28px rgba(216,176,107,.12));
}
.mandala::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:conic-gradient(from 0deg,
    transparent 0 28deg, rgba(216,176,107,.16) 28deg 29deg,
    transparent 29deg 58deg, rgba(216,176,107,.12) 58deg 59deg,
    transparent 59deg 88deg, rgba(216,176,107,.16) 88deg 89deg,
    transparent 89deg 118deg, rgba(216,176,107,.12) 118deg 119deg,
    transparent 119deg 148deg, rgba(216,176,107,.16) 148deg 149deg,
    transparent 149deg 178deg, rgba(216,176,107,.12) 178deg 179deg,
    transparent 179deg 208deg, rgba(216,176,107,.16) 208deg 209deg,
    transparent 209deg 238deg, rgba(216,176,107,.12) 238deg 239deg,
    transparent 239deg 268deg, rgba(216,176,107,.16) 268deg 269deg,
    transparent 269deg 298deg, rgba(216,176,107,.12) 298deg 299deg,
    transparent 299deg 328deg, rgba(216,176,107,.16) 328deg 329deg,
    transparent 329deg 360deg);
  mask:radial-gradient(circle, transparent 0 56%, #000 56.2% 76%, transparent 76.2%);
}
.taiji,
.empty-taiji{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:52px;
  aspect-ratio:1;
  border-radius:50%;
  overflow:hidden;
  box-shadow:0 0 24px rgba(216,176,107,.14), inset 0 0 0 2px rgba(216,176,107,.16);
  animation:breathe 6s ease-in-out infinite;
}
.taiji::before,
.empty-taiji::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,#11151b 0 50%,#f6ecd7 50% 100%);
}
.taiji .half-top,.taiji .half-bottom,
.empty-taiji .half-top,.empty-taiji .half-bottom{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:26px;
  height:26px;
  border-radius:50%;
}
.taiji .half-top,.empty-taiji .half-top{top:0;background:#11151b}
.taiji .half-bottom,.empty-taiji .half-bottom{bottom:0;background:#f6ecd7}
.taiji .dot-top,.taiji .dot-bottom,
.empty-taiji .dot-top,.empty-taiji .dot-bottom{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:6px;
  height:6px;
  border-radius:50%;
}
.taiji .dot-top,.empty-taiji .dot-top{top:10px;background:#f6ecd7}
.taiji .dot-bottom,.empty-taiji .dot-bottom{bottom:10px;background:#11151b}
.brand-copy{min-width:0}
.brand-copy h1{margin:6px 0 6px;font-size:37px;font-weight:500;line-height:1.04;letter-spacing:-.02em}
.eyebrow,.kicker{
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:11px;
}
.brand-note{margin:0;color:var(--muted);line-height:1.65;max-width:760px}
.ghost-link{
  color:var(--muted);
  text-decoration:none;
  border:1px solid var(--line);
  padding:11px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  white-space:nowrap;
}
.top-actions{justify-self:end}
.wrap{
  max-width:1180px;
  margin:0 auto;
  padding:8px 22px 40px;
  display:grid;
  gap:18px;
}
.panel{
  border:1px solid var(--line);
  border-radius:30px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)), linear-gradient(180deg,var(--panel),var(--panel-2));
  box-shadow:var(--shadow);
  padding:24px;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(14px);
}
.panel::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 88% 8%, rgba(216,176,107,.11), transparent 18%),
    radial-gradient(circle at 12% 100%, rgba(122,49,66,.08), transparent 18%);
}

.panel::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:29px;
  pointer-events:none;
  background:linear-gradient(135deg, rgba(216,176,107,.05), transparent 18%, transparent 82%, rgba(216,176,107,.04));
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  padding:1px;
  -webkit-mask-composite:xor;
  mask-composite:exclude;
}
.avatar-btn::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:1px solid rgba(216,176,107,.07);
}
.question-box .meta-text{font-size:17px;color:var(--ink)}
.result-panel .empty-state p{max-width:760px;margin:0 auto}
.memory-actions{justify-content:flex-end}
.memory-panel .section-head{margin-bottom:16px}
.note-area{line-height:1.75}
.memory-empty{padding:10px 4px 4px}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:18px;
}
.section-head.compact{align-items:center;margin-bottom:12px}
.section-head h2,.empty-state h2{margin:6px 0 0;font-size:30px;font-weight:500;letter-spacing:-.02em}
.section-glyph{color:var(--gold);font-size:26px;line-height:1;opacity:.9}
.mode-switch,.action-row,.memory-actions,.result-actions,.note-actions,.ia-actions,.small-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.memory-head{align-items:center}
.mode-btn,.btn,.auth-tab,.close-btn{
  appearance:none;
  border:none;
  cursor:pointer;
  border-radius:18px;
  padding:12px 16px;
  font-size:15px;
  font-family:inherit;
  transition:.22s ease;
}
.mode-btn:hover,.btn:hover,.auth-tab:hover,.ghost-link:hover,.avatar-btn:hover{transform:translateY(-1px)}
.mode-btn,.btn,.auth-tab{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--ink);
}
.mode-btn.active,.btn.primary,.auth-tab.active{
  background:linear-gradient(180deg, var(--gold-soft), var(--gold));
  color:#24190c;
  font-weight:700;
}
.field{display:block;margin-bottom:16px}
.field span{display:block;color:var(--muted);font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
input,textarea{
  width:100%;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)), rgba(0,0,0,.24);
  color:var(--ink);
  border:1px solid rgba(216,176,107,.12);
  border-radius:22px;
  padding:15px 16px;
  font-size:16px;
  font-family:inherit;
  outline:none;
}
textarea{min-height:120px;resize:vertical}
input:focus,textarea:focus{border-color:rgba(216,176,107,.38);box-shadow:0 0 0 4px rgba(216,176,107,.08)}
.hidden,.manual-box.hidden{display:none!important}
.hint,.empty-state p,.meta-text,.auth-message,.memory-empty,.inline-note,.subtle-hint{color:var(--muted);line-height:1.75}
.empty-state{text-align:center;padding:18px 4px 8px}
.subtle-hint{margin:-4px 0 16px;font-size:14px}
.empty-emblem{height:90px;position:relative;margin-bottom:8px}
.result-core{display:grid;gap:18px}
.question-box,.hex-row,.ia-box,.note-box,.memory-item,.status-pill,.meta-grid,.ritual-status,.ritual-step,.ritual-figure-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.03);
}
.question-box,.ia-box,.note-box,.memory-item,.ritual-status{padding:18px}
.meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;overflow:hidden}
.meta-grid div{padding:14px 16px;background:rgba(0,0,0,.14)}
.meta-grid strong{display:block;color:var(--gold);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.hex-row{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;padding:18px;align-items:center}
.arrow{color:var(--gold);font-size:26px;text-align:center}
.hex-card{text-align:center}
.hex-symbol{font-size:52px;color:var(--gold);line-height:1}
.hex-name{font-size:22px;margin-top:10px}
.hex-num{color:var(--muted);margin-top:6px}
.lines-view,.ritual-figure{max-width:170px;margin:16px auto 0}
.line{height:18px;margin:10px 0;position:relative;filter:drop-shadow(0 0 14px rgba(216,176,107,.08));animation:lineAppear .45s ease both}
.line.yang::before,.line.yin::before,.line.yin::after{
  content:"";
  position:absolute;
  top:5px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, #fef6e7, #d5b271 50%, #fef6e7);
}
.line.yang::before{left:0;right:0}
.line.yin::before{left:0;width:42%}
.line.yin::after{right:0;width:42%}
.line.mutating{outline:2px solid rgba(216,176,107,.55);outline-offset:4px;border-radius:12px;box-shadow:0 0 24px rgba(216,176,107,.10)}
.ia-box h3,.note-box h3,.memory-item h3{margin:0 0 12px;font-size:20px;font-weight:500}
.ia-content p{margin:0 0 12px;line-height:1.8}
.note-area{min-height:110px}
.status-pill{display:inline-flex;align-items:center;padding:8px 12px;color:var(--muted)}
.memory-list{display:grid;gap:14px}
.memory-item{display:grid;gap:12px;padding:18px 18px 16px;background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02))}
.memory-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.memory-title{line-height:1.55;font-size:18px}
.memory-meta{color:var(--muted);line-height:1.6;font-size:14px}
.memory-flags{display:flex;gap:8px;flex-wrap:wrap}
.memory-flag{display:inline-flex;align-items:center;padding:5px 9px;border:1px solid rgba(216,176,107,.16);border-radius:999px;font-size:12px;color:var(--gold-soft);background:rgba(255,255,255,.025)}

.ritual-core{gap:20px}
.ritual-status{text-align:center;color:var(--ink)}
.ritual-layout{display:grid;grid-template-columns:1.5fr .8fr;gap:16px;align-items:start}
.ritual-trace{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.ritual-step{padding:16px;min-height:180px;display:flex;flex-direction:column;justify-content:center;gap:12px}
.ritual-step.active{box-shadow:0 0 0 1px rgba(216,176,107,.28), 0 0 28px rgba(216,176,107,.08)}
.ritual-step-head{display:flex;justify-content:space-between;gap:12px;align-items:center}
.ritual-step-title{font-size:14px;color:var(--gold-soft)}
.ritual-step-state,.ritual-step-value{color:var(--muted);line-height:1.6}
.ritual-figure-card{padding:18px;text-align:center}
.ritual-figure-card strong{display:block;color:var(--gold);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.ritual-empty{color:var(--muted);line-height:1.7;padding:14px 0}
.coin-row{display:flex;gap:12px;justify-content:center;align-items:center;min-height:70px}
.coin-chip{
  width:58px;
  height:58px;
  border-radius:50%;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#704e1d;
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
  background:
    radial-gradient(circle at 35% 32%, rgba(255,255,255,.34), transparent 18%),
    linear-gradient(180deg,#f4ddb1,#c89d53);
  box-shadow:inset 0 0 0 2px rgba(112,78,29,.45), inset 0 0 0 8px rgba(255,239,205,.14), 0 10px 20px rgba(0,0,0,.28);
}
.coin-chip::before{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:50%;
  border:2px solid rgba(112,78,29,.55);
}
.coin-chip.pending{
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.45);
  box-shadow:none;
  border:1px dashed rgba(216,176,107,.18);
}
.coin-chip.pending::before{display:none}
.coin-chip.flipping{animation:flipCoin .8s ease-in-out 3}

.user-menu{
  position:fixed;
  left:22px;
  top:84px;
  z-index:5;
  min-width:250px;
  border:1px solid var(--line);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015)), linear-gradient(180deg,var(--panel),var(--panel-2));
  box-shadow:var(--shadow);
  padding:14px;
}
.user-menu .menu-user{padding:10px 8px 14px;line-height:1.7}
.user-menu button,.user-menu a{
  width:100%;
  display:block;
  text-align:left;
  margin-top:8px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--ink);
  text-decoration:none;
  border-radius:16px;
  padding:12px 14px;
  font-family:inherit;
  cursor:pointer;
}

.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.48);
  display:grid;
  place-items:center;
  z-index:8;
  padding:20px;
}
.modal-card{
  width:min(520px,100%);
  border:1px solid var(--line);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)), linear-gradient(180deg,var(--panel),var(--panel-2));
  box-shadow:var(--shadow);
  padding:22px;
}
.auth-modal-card{
  width:min(560px,100%);
  max-height:min(92vh, 760px);
  overflow:auto;
  padding:18px 18px 20px;
  background:
    radial-gradient(circle at top left, rgba(216,176,107,.12), transparent 34%),
    linear-gradient(180deg, rgba(20,21,28,.97), rgba(10,11,15,.985));
  box-shadow:0 28px 90px rgba(0,0,0,.52);
}
.modal-head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:12px}
.modal-head h3{margin:0;font-size:28px;font-weight:500}
.auth-tabs{display:flex;gap:10px;margin-bottom:12px}
.auth-form{display:grid;gap:8px}
.close-btn{background:rgba(255,255,255,.04);color:var(--ink);border:1px solid var(--line)}
.full{width:100%}
.auth-shell{display:grid;gap:18px}
.auth-shell-mark{
  width:62px;
  height:62px;
  border-radius:20px;
  display:grid;
  place-items:center;
  border:1px solid rgba(216,176,107,.18);
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.08), rgba(255,255,255,.02));
  color:var(--gold-soft);
  font-size:28px;
  box-shadow:0 0 0 1px rgba(255,255,255,.02) inset;
}
.auth-shell-copy{display:grid;gap:8px}
.auth-shell-intro{margin:0;color:var(--muted);line-height:1.7}
.auth-switch{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;
  padding:4px;
  border-radius:999px;
  border:1px solid rgba(216,176,107,.12);
  background:rgba(255,255,255,.035);
}
.auth-switch .auth-tab{
  width:100%;
  justify-content:center;
  text-align:center;
}
.auth-form-spacious{gap:12px}
.auth-field-compact{margin-bottom:0}
.auth-step-head{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.auth-step-copy{
  display:grid;
  gap:4px;
}
.auth-step-copy strong{
  color:var(--gold-soft);
  font-size:14px;
  letter-spacing:.08em;
}
.auth-step-copy span{
  color:var(--muted);
  line-height:1.5;
  word-break:break-word;
}
.auth-back-btn{
  padding:10px 14px;
  border-radius:999px;
  white-space:nowrap;
}
.auth-inline-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:14px;
  margin-bottom:-2px;
}
.auth-inline-head span{
  color:var(--muted);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.auth-inline-link{
  color:var(--gold-soft);
  text-decoration:none;
  font-size:14px;
}
.auth-inline-link-row{
  display:flex;
  justify-content:flex-end;
}
.auth-inline-link:hover{color:var(--ink)}
.auth-provider-block{display:grid;gap:10px}
.auth-provider-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.oauth-provider-btn{
  appearance:none;
  border:1px solid rgba(216,176,107,.14);
  background:rgba(255,255,255,.045);
  color:var(--ink);
  border-radius:18px;
  min-height:58px;
  padding:12px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-size:15px;
  transition:.22s ease;
}
.oauth-provider-btn:hover:not([disabled]){
  transform:translateY(-1px);
  border-color:rgba(216,176,107,.28);
  background:rgba(255,255,255,.07);
}
.oauth-provider-btn[disabled]{
  opacity:.48;
  cursor:not-allowed;
}
.oauth-provider-glyph{
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  flex:none;
  font-weight:700;
}
.oauth-provider-glyph-google{
  font-size:22px;
  color:#f4f1eb;
}
.oauth-provider-glyph-ms{
  grid-template-columns:repeat(2,1fr);
  gap:2px;
  padding:2px;
}
.oauth-provider-glyph-ms span:nth-child(1){background:#f25022}
.oauth-provider-glyph-ms span:nth-child(2){background:#7fba00}
.oauth-provider-glyph-ms span:nth-child(3){background:#00a4ef}
.oauth-provider-glyph-ms span:nth-child(4){background:#ffb900}
.auth-provider-note{
  min-height:20px;
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}
.auth-divider{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--muted);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.auth-divider::before,.auth-divider::after{
  content:"";
  flex:1;
  height:1px;
  background:rgba(216,176,107,.12);
}
.auth-legal-row{
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding-top:6px;
  border-top:1px solid rgba(216,176,107,.12);
}
.auth-legal-row a{
  color:var(--muted);
  text-decoration:none;
}
.auth-legal-row a:hover{color:var(--gold-soft)}
.auth-provider-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.auth-provider-summary div{
  border:1px solid rgba(216,176,107,.12);
  border-radius:18px;
  padding:12px 14px;
  background:rgba(255,255,255,.035);
}
.auth-provider-summary strong{
  display:block;
  color:var(--muted);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.auth-provider-summary span{color:var(--ink)}
.auth-checks{display:grid;gap:10px}
.auth-provider-hint-card{
  border:1px solid rgba(216,176,107,.14);
  border-radius:22px;
  padding:16px 18px;
  background:rgba(255,255,255,.035);
}
.auth-provider-hint-card h4{
  margin:0 0 8px;
  font-size:22px;
  font-weight:500;
}
.auth-provider-hint-card p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
}

@keyframes slowspin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes breathe{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.04)}}
@keyframes lineAppear{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes flipCoin{0%{transform:translateY(0) rotateY(0deg)}50%{transform:translateY(-12px) rotateY(180deg)}100%{transform:translateY(0) rotateY(360deg)}}

@media (max-width:960px){
  .topbar{grid-template-columns:1fr;gap:14px}
  .avatar-btn{left:22px;top:18px}
  .brand-block{padding-left:58px}
  .top-actions{justify-self:start;padding-left:58px}
  .ritual-layout,.hex-row{grid-template-columns:1fr}
  .arrow{transform:rotate(90deg)}
  .meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:720px){
  body::after{display:none}
  .topbar,.wrap{padding-left:14px;padding-right:14px}
  .avatar-btn{left:14px;top:18px}
  .brand-block{padding-left:50px;gap:12px;align-items:flex-start}
  .top-actions{padding-left:50px}
  .brand-art{width:82px;height:82px;flex-basis:82px}
  .brand-copy h1{font-size:32px}
  .section-head h2,.empty-state h2{font-size:26px}
  .memory-top,.ritual-trace{grid-template-columns:1fr;display:grid}
  .ritual-trace{grid-template-columns:1fr}
  .meta-grid{grid-template-columns:1fr}
}

.top-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.toolbar-links .ghost-link{display:inline-flex;align-items:center;justify-content:center}
.mode-field{
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px 18px 16px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  margin-bottom:16px;
}
.mode-label{
  text-align:center;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.centered-switch{justify-content:center;align-items:center}
.centered-switch .mode-btn{min-width:146px;padding:14px 18px;border-radius:999px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.question-field{margin-top:4px}
.question-field textarea{min-height:148px}
.action-row-centered{justify-content:flex-start;align-items:center}
.quiet-status{margin:0 0 0 4px;min-height:24px}
.inline-link-row{display:flex;flex-wrap:wrap;gap:10px}
.study-panel .section-head{margin-bottom:14px}
.study-empty{padding:8px 0}
.study-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.study-card{
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  display:grid;
  gap:12px;
}
.study-card h3{margin:0;font-size:24px;font-weight:500}
.study-card p{margin:0;line-height:1.8;color:var(--ink)}
.study-wide{grid-column:1/-1}
.large{font-size:64px}
.trigram-pair{display:flex;gap:10px;flex-wrap:wrap}
.tri-chip{
  display:inline-grid;
  gap:4px;
  padding:10px 12px;
  border:1px solid rgba(216,176,107,.14);
  border-radius:18px;
  background:rgba(255,255,255,.025);
  color:var(--gold-soft);
  font-size:13px;
}
.tri-chip strong{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.helper-text{color:var(--muted)!important}
.line-role-list{margin:0;padding-left:18px;display:grid;gap:10px;color:var(--muted);line-height:1.75}
.line-role-list strong{color:var(--gold-soft)}
.user-menu{
  backdrop-filter:blur(16px);
  min-width:270px;
}
.user-menu .menu-user strong{font-size:18px}
.user-menu .menu-user span{color:var(--muted)}
.page-shell{max-width:1180px;margin:0 auto;padding:28px 22px 42px}
.page-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}
.page-hero-copy{max-width:760px}
.page-hero-copy h1{margin:8px 0 12px;font-size:52px;font-weight:500;letter-spacing:-.03em}
.page-hero-copy p{margin:0;color:var(--muted);line-height:1.8;font-size:18px}
.page-actions{display:flex;gap:10px;flex-wrap:wrap}
.content-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.info-list{display:grid;gap:12px}
.info-list .study-card strong{color:var(--gold-soft)}
.profile-layout,.manual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.profile-auth-card{
  grid-column:1/-1;
  width:min(680px,100%);
  margin:0 auto;
  padding:0;
  overflow:hidden;
}
.auth-focus-card{
  background:
    radial-gradient(circle at top left, rgba(216,176,107,.14), transparent 32%),
    linear-gradient(180deg, rgba(19,20,27,.965), rgba(10,11,15,.99));
  box-shadow:0 30px 80px rgba(0,0,0,.34);
}
.profile-card,.manual-card,.detail-frame,.hex-tile{
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  padding:18px;
}
.profile-card h2,.manual-card h2,.detail-frame h2{margin:0 0 12px;font-size:30px;font-weight:500}
.profile-card h3,.manual-card h3,.detail-frame h3{margin:0 0 10px;font-size:22px;font-weight:500}
.profile-card p,.manual-card p,.detail-frame p,.detail-frame li{color:var(--muted);line-height:1.8}
.profile-card form{display:grid;gap:10px}
.auth-focus-card input{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)), rgba(0,0,0,.18);
  border-color:rgba(216,176,107,.16);
}
.auth-focus-card .auth-message{
  min-height:22px;
  color:var(--gold-soft);
  margin:0;
}
.success-note{color:var(--gold-soft);min-height:22px}
.search-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.search-row input{flex:1 1 280px}
.hex-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.hex-tile{cursor:pointer;transition:.2s ease;display:grid;gap:8px}
.hex-tile:hover{transform:translateY(-2px);border-color:rgba(216,176,107,.28)}
.hex-tile .n{color:var(--gold);font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.hex-tile .t{font-size:19px;line-height:1.45}
.detail-frame .hex-symbol{font-size:82px}
.detail-frame .meta-grid{margin-top:14px}
.manual-sections{display:grid;gap:18px}
.manual-step{padding-left:20px;position:relative}
.manual-step::before{content:"";position:absolute;left:0;top:.8em;width:8px;height:8px;border-radius:50%;background:var(--gold)}
@media (max-width:960px){
  .study-grid,.content-grid,.profile-layout,.manual-grid,.hex-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .top-actions{justify-content:flex-start}
  .centered-switch .mode-btn{min-width:0;flex:1 1 0}
  .study-grid,.content-grid,.profile-layout,.manual-grid,.hex-grid{grid-template-columns:1fr}
  .page-shell{padding-left:14px;padding-right:14px}
  .page-hero{flex-direction:column}
  .page-hero-copy h1{font-size:38px}
  .action-row-centered{justify-content:stretch}
  .auth-provider-grid,.auth-provider-summary{grid-template-columns:1fr}
  .auth-inline-head{flex-direction:column;align-items:flex-start}
  .auth-legal-row{justify-content:flex-start}
}

/* --- 3.8 cierre de experiencia principal --- */
.topbar-centered{
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  padding-top: 16px;
}
.topbar-centered .brand-block{
  padding-left: 0;
  justify-content: center;
}
.centered-header-actions{
  justify-self: center;
  justify-content: center;
}
.consult-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.9fr);
  gap:18px;
  align-items:start;
}
.consult-form{min-width:0}
.ritual-side-panel{
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  padding:18px;
  display:grid;
  gap:14px;
  min-height:100%;
}
.ritual-side-top{display:flex;justify-content:space-between;gap:12px;align-items:start}
.ritual-side-top h3{margin:6px 0 0;font-size:24px;font-weight:500}
.mini-help-btn{
  appearance:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--gold-soft);
  border-radius:999px;
  padding:8px 12px;
  font-family:inherit;
  cursor:pointer;
}
.ritual-side-shell{display:grid;gap:14px}
.ritual-side-idle,
.ritual-side-result,
.ritual-side-figure,
.ritual-side-question,
.ritual-side-foot{
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.03);
  padding:14px 16px;
}
.ritual-side-idle{min-height:260px;place-items:center;text-align:center;display:grid}
.ritual-side-idle p{margin:0;color:var(--muted);line-height:1.8}
.ritual-side-coin{font-size:54px;color:var(--gold);opacity:.9}
.ritual-side-question{color:var(--muted);line-height:1.75}
.ritual-side-trace{display:grid;gap:12px;max-height:480px;overflow:auto;padding-right:2px}
.ritual-side-trace .ritual-step{min-height:0}
.ritual-side-result h3{margin:8px 0 10px;font-size:24px;font-weight:500}
.compact-figure{padding-top:16px;padding-bottom:16px}
.result-bridge{
  border-left:2px solid rgba(216,176,107,.22);
  padding:4px 0 4px 14px;
}
.result-bridge p{margin:0;color:var(--muted);line-height:1.8}
.ai-panel .section-head,.note-panel-wrap .section-head{margin-bottom:14px}
.standalone-box{padding:18px}
.text-block{display:grid;gap:6px}
.text-block strong{color:var(--gold-soft);font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.text-block p{margin:0;color:var(--muted);line-height:1.82}
.detail-frame .text-block p{color:var(--muted)}
.memory-panel{margin-top:0}
.user-menu{top:86px}
@media (max-width:960px){
  .consult-grid{grid-template-columns:1fr}
  .topbar-centered .top-actions{padding-left:0;justify-self:center}
}
@media (max-width:720px){
  .topbar-centered{justify-items:start;text-align:left}
  .topbar-centered .brand-block{padding-left:50px;justify-content:flex-start}
  .centered-header-actions{justify-self:start}
}

/* --- 3.9 biblioteca + líneas + manual --- */
.library-grid{grid-template-columns:minmax(280px,380px) minmax(0,1fr)}
.library-list-panel{align-self:start}
.library-detail-panel{min-height:520px}
.library-card-block p{white-space:pre-line}
.ceremonial-search-row{display:flex;flex-direction:column;gap:8px}
.search-note{font-size:.92rem;color:var(--muted)}
.moving-lines-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:14px}
.line-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(255,255,255,.025);box-shadow:0 18px 50px rgba(0,0,0,.16)}
.line-kicker{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.line-card h4{margin:8px 0 10px;font-size:1rem;line-height:1.45;color:var(--gold-soft)}
.line-commentary{margin:0;color:var(--ink);line-height:1.65}
.line-details{margin-top:12px;border-top:1px solid rgba(216,176,107,.12);padding-top:10px}
.line-details summary{cursor:pointer;color:var(--gold-soft)}
.line-details p{margin:10px 0 0;white-space:pre-line;line-height:1.68}
.top-actions .ghost-link{min-width:120px;text-align:center}
@media (max-width: 980px){
  .library-grid{grid-template-columns:1fr}
  .moving-lines-grid{grid-template-columns:1fr}
}


/* --- 4.0 ajustes rituales y biblioteca viva --- */
.action-row-centered{justify-content:center;align-items:center}
.ritual-btn{
  min-width:220px;
  padding:15px 26px;
  border-radius:999px;
  box-shadow:0 14px 30px rgba(216,176,107,.18), inset 0 1px 0 rgba(255,255,255,.35);
  letter-spacing:.04em;
}
.consult-panel{scroll-margin-top:18px}
.consult-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:22px}
.ritual-side-panel{position:sticky;top:18px;overflow:hidden}
.ritual-side-panel::before{
  content:"";
  position:absolute;
  inset:-30% -20% auto auto;
  width:180px;
  height:180px;
  background:radial-gradient(circle, rgba(216,176,107,.10), transparent 65%);
  pointer-events:none;
}
.ritual-side-top,.ritual-side-shell{position:relative;z-index:1}
.ritual-side-idle{min-height:340px;background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02))}
.ritual-side-idle .ritual-side-coin{font-size:62px;filter:drop-shadow(0 0 18px rgba(216,176,107,.18))}
.ritual-side-question{font-style:italic}
.ritual-step{
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  box-shadow:0 18px 42px rgba(0,0,0,.16);
}
.coin-row{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start}
.coin-chip{
  width:82px;height:82px;border-radius:50%;
  border:1px solid rgba(216,176,107,.25);
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.16), rgba(255,255,255,.04) 42%, rgba(0,0,0,.22));
  display:grid;place-items:center;position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22), 0 14px 28px rgba(0,0,0,.22);
  perspective:900px;
}
.coin-chip::after{
  content:"";
  position:absolute;
  inset:6px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.10);
  pointer-events:none;
}
.coin-face{
  width:100%;height:100%;display:block;border-radius:50%;
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.22));
}
.coin-face.odd{background-image:var(--coin-face-odd)}
.coin-face.even{background-image:var(--coin-face-even)}
.coin-face.placeholder{
  background:none;
  position:relative;
}
.coin-face.placeholder::before{
  content:"☯";
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:26px;color:rgba(216,176,107,.78);
}
.coin-chip .coin-value{
  position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  font-size:10px;color:#2a1d0c;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(242,214,160,.9);padding:3px 7px;border-radius:999px;
  box-shadow:0 3px 10px rgba(0,0,0,.18);
}
.coin-chip.pending{opacity:.56;border-style:dashed}
.coin-chip.pending .coin-value{background:rgba(255,255,255,.14);color:var(--gold-soft)}
.coin-chip.flipping{animation:coinPulse 1.05s cubic-bezier(.18,.7,.2,1) both}
.coin-chip.tossing{animation:coinFloat .9s ease-in-out infinite}
.coin-chip.settled{transform:translateY(0)}
@keyframes coinPulse{0%{transform:translateY(18px) scale(.72) rotateY(0deg);opacity:.12}35%{transform:translateY(-10px) scale(1.02) rotateY(540deg);opacity:1}68%{transform:translateY(2px) scale(.98) rotateY(880deg)}100%{transform:translateY(0) scale(1) rotateY(1080deg);opacity:1}}
@keyframes coinFloat{0%,100%{transform:translateY(0) scale(.94);opacity:.45}50%{transform:translateY(-8px) scale(1.02);opacity:.9}}
.ritual-side-foot{color:var(--gold-soft)}
.ritual-side-result .ritual-figure,.ritual-side-figure .ritual-figure{margin-top:10px}
.ritual-side-result p{margin:12px 0 0;color:var(--muted);line-height:1.75}
.search-row.ceremonial-search-row{
  margin:20px 0 18px;
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  display:grid;
  gap:12px;
}
.search-row.ceremonial-search-row input{height:48px;padding:0 16px;max-width:540px}
.search-row.ceremonial-search-row .search-note{max-width:860px}
.library-grid{grid-template-columns:320px minmax(0,1fr);align-items:start;gap:20px}
.library-list-panel{position:sticky;top:18px;max-height:calc(100vh - 44px);overflow:auto}
.library-detail-panel{min-height:640px}
.hex-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.hex-tile{padding:14px 14px 16px;min-height:118px;align-content:start}
.hex-tile .t{font-size:17px;line-height:1.35}
.hex-tile.is-active{border-color:rgba(216,176,107,.42);box-shadow:0 16px 40px rgba(0,0,0,.18);background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03))}
.library-detail-head{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start}
.library-detail-head .hex-symbol{font-size:56px;line-height:1}
.library-detail-copy h2{margin:0 0 8px;font-size:48px;letter-spacing:-.03em}
.library-detail-copy .inline-note{margin:0}
.library-detail-panels{display:grid;gap:16px;margin-top:18px}
.library-card-block{padding:18px 20px}
.library-card-block p{margin:0;color:var(--ink);line-height:1.82;white-space:pre-line}
.library-card-block .inline-note{margin:0 0 12px;color:var(--muted)}
.library-detail-panel .meta-grid{margin-top:18px;grid-template-columns:repeat(4,minmax(0,1fr))}
.library-detail-panel .meta-grid div{min-height:100%}
@media (max-width:1100px){
  .library-detail-head .hex-symbol{font-size:48px}
  .library-detail-copy h2{font-size:40px}
}
@media (max-width:980px){
  .ritual-side-panel{position:relative;top:auto}
  .library-grid{grid-template-columns:1fr}
  .library-list-panel{position:relative;top:auto;max-height:none}
}
@media (max-width:720px){
  .ritual-btn{width:100%;min-width:0}
  .coin-chip{width:70px;height:70px}
  .hex-grid{grid-template-columns:1fr 1fr}
  .library-detail-panel .meta-grid{grid-template-columns:1fr 1fr}
  .library-detail-copy h2{font-size:34px}
}


.method-sections{gap:14px}
.method-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:6px}
.method-grid div{border:1px solid var(--line);border-radius:18px;padding:14px 12px;background:rgba(255,255,255,.03)}
.method-grid strong{display:block;font-size:28px;color:var(--gold-soft);margin-bottom:6px}
.method-grid span{display:block;color:var(--muted);line-height:1.45}
.manual-wide{grid-column:1 / -1}
@media (max-width:720px){
  .method-grid{grid-template-columns:1fr 1fr}
}


/* --- 4.4 monedas separadas + ceremonia con más protagonismo --- */
.ritual-side-note{margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.5}
.consult-grid{grid-template-columns:minmax(0,1fr) minmax(560px,1.12fr);gap:26px;align-items:start}
.ritual-side-panel{min-height:760px;background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));box-shadow:0 24px 80px rgba(0,0,0,.28)}
.ritual-side-shell{display:grid;gap:18px}
.ritual-stage-wrap{display:grid;grid-template-columns:minmax(0,1fr) 220px;grid-template-areas:"stage formation" "history formation";gap:16px;align-items:start}
.ritual-stage{grid-area:stage}
.ritual-formation-map{grid-area:formation}
.ritual-history{grid-area:history}
.ritual-stage,
.ritual-formation-map,
.ritual-history{border:1px solid rgba(216,176,107,.18);border-radius:24px;background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));padding:18px 18px 16px;box-shadow:0 18px 40px rgba(0,0,0,.16)}
.ritual-stage-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.ritual-stage-head h4{margin:6px 0 0;font-size:38px;line-height:1.02}
.ritual-stage-meta{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-soft);padding-top:4px}
.ritual-side-question.prominent{margin:14px 0 18px;padding:16px 18px;border-radius:20px;border:1px solid rgba(216,176,107,.14);background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));font-size:18px;line-height:1.65;color:var(--ink)}
.big-coin-row{display:flex;justify-content:center;align-items:center;gap:24px;min-height:264px;padding:18px 8px 14px;position:relative;overflow:visible}
.big-coin-row::before{content:"";position:absolute;inset:6% 12%;background:radial-gradient(circle, rgba(216,176,107,.16), transparent 70%);pointer-events:none}
.big-coin-row::after{content:"";position:absolute;left:12%;right:12%;bottom:18px;height:18px;border-radius:50%;background:radial-gradient(circle, rgba(0,0,0,.35), transparent 72%);filter:blur(16px);pointer-events:none}
.coin-chip.large{width:154px;height:154px;border-color:rgba(216,176,107,.34);box-shadow:0 26px 54px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.22);background:radial-gradient(circle at 28% 24%, rgba(255,255,255,.16), rgba(255,255,255,.04) 38%, rgba(0,0,0,.26))}
.coin-chip.large::after{inset:10px;border-color:rgba(255,255,255,.14)}
.coin-chip.compact{width:58px;height:58px}
.coin-row.compact-row{gap:10px;justify-content:flex-start}
.coin-chip.large .coin-value{bottom:8px;font-size:12px;padding:4px 8px}
.coin-chip.compact .coin-value{bottom:4px;font-size:9px;padding:2px 6px}
.coin-chip.large.flipping{animation:coinPulseLarge 1.55s cubic-bezier(.16,.78,.2,1) both}
.coin-chip.large.tossing{animation:coinFloatLarge 1.2s ease-in-out infinite}
.coin-chip.flipping .coin-face{animation:coinFaceFlash 1s linear both}
@keyframes coinPulseLarge{
  0%{transform:translateY(42px) scale(.52) rotateY(0deg) rotateX(0deg);opacity:.06}
  16%{transform:translateY(-22px) scale(.86) rotateY(420deg) rotateX(18deg);opacity:1}
  42%{transform:translateY(-46px) scale(1.08) rotateY(960deg) rotateX(5deg)}
  68%{transform:translateY(10px) scale(.97) rotateY(1320deg) rotateX(-6deg)}
  100%{transform:translateY(0) scale(1) rotateY(1440deg) rotateX(0deg);opacity:1}
}
@keyframes coinFloatLarge{
  0%,100%{transform:translateY(0) scale(.95);opacity:.58}
  50%{transform:translateY(-22px) scale(1.04);opacity:1}
}
@keyframes coinFaceFlash{
  0%,100%{filter:drop-shadow(0 4px 10px rgba(0,0,0,.22)) brightness(1)}
  50%{filter:drop-shadow(0 12px 24px rgba(216,176,107,.22)) brightness(1.1)}
}
.ritual-stage-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px}
.ritual-stage-stats span{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:16px;border:1px solid rgba(216,176,107,.14);background:rgba(255,255,255,.03);color:var(--muted)}
.ritual-stage-stats strong{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft)}
.ritual-formation-map{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:100%}
.ritual-figure.large-formation{min-height:194px;display:flex;flex-direction:column;justify-content:center;gap:10px;width:100%;max-width:180px;margin:12px auto}
.formation-caption{font-size:14px;line-height:1.6;color:var(--muted)}
.ritual-history-list{display:grid;gap:10px}
.ritual-step.compact{padding:12px 14px;border-radius:18px}
.ritual-step.compact .ritual-step-title{font-size:18px}
.ritual-step.compact .ritual-step-state{font-size:13px}
.elevated-result .ritual-stage-wrap{align-items:center}
.result-stage-wrap{grid-template-columns:minmax(0,1fr) minmax(200px,.55fr);grid-template-areas:"stage formation"}
.result-stage .ritual-figure{max-width:180px;margin:12px auto 0}
.ritual-side-result h3{margin:6px 0 0;font-size:32px;line-height:1.08}

@media (max-width: 1280px){
  .consult-grid{grid-template-columns:1fr}
  .ritual-side-panel{position:relative;top:auto;min-height:auto}
}
@media (max-width: 980px){
  .ritual-stage-wrap,.result-stage-wrap{grid-template-columns:1fr;grid-template-areas:"stage" "formation" "history"}
}
@media (max-width: 760px){
  .big-coin-row{gap:12px;min-height:170px}
  .coin-chip.large{width:104px;height:104px}
  .coin-chip.large .coin-value{font-size:10px}
  .ritual-stage-head h4{font-size:28px}
  .ritual-stage-stats{grid-template-columns:1fr}
}

/* --- 4.5 fix ritual: monedas visibles, sin duplicación, proporciones sanas --- */
.consult-grid{grid-template-columns:minmax(0,1fr) 430px !important;gap:24px !important;align-items:start}
.ritual-side-panel{min-height:620px !important;padding:18px !important}
.ritual-side-shell{display:grid;gap:14px !important}
.ritual-stage-wrap{display:grid;grid-template-columns:1fr 150px !important;grid-template-areas:"stage formation" !important;gap:14px !important;align-items:start}
.ritual-history{display:none}
.ritual-stage,
.ritual-formation-map{padding:16px 16px 14px !important}
.ritual-stage-head h4{font-size:34px !important}
.ritual-side-question.prominent{margin:12px 0 14px !important;padding:14px 16px !important;font-size:17px !important}
.big-coin-row{gap:16px !important;min-height:190px !important;padding:10px 4px 8px !important}
.big-coin-row::before{inset:12% 10% !important}
.big-coin-row::after{bottom:12px !important}
.coin-chip{overflow:hidden;padding:0 !important;background:radial-gradient(circle at 30% 24%, rgba(255,255,255,.10), rgba(0,0,0,.18)) !important}
.coin-chip.large{width:112px !important;height:112px !important}
.coin-chip.compact{width:44px !important;height:44px !important}
.coin-chip::before{display:none !important}
.coin-chip::after{inset:4px !important;border-color:rgba(255,255,255,.10) !important}
.coin-image{display:block;width:100%;height:100%;object-fit:cover;object-position:center center;border-radius:50%}
.coin-chip.pending .coin-image{display:none}
.coin-chip .coin-value{bottom:4px !important;font-size:10px !important;padding:3px 6px !important}
.coin-chip.compact .coin-value{display:none}
.ritual-stage-stats{grid-template-columns:1fr 1fr !important}
.ritual-stage-stats span{padding:10px 12px !important}
.ritual-formation-map{min-height:100%;justify-content:flex-start !important}
.ritual-figure.large-formation{min-height:150px !important;max-width:136px !important;margin:20px auto 10px !important}
.formation-caption{font-size:13px !important}
.result-core.ritual-core{padding:6px 2px 0 !important;gap:12px !important}
.result-core.ritual-core h2{font-size:26px !important;margin:0}
.result-core.ritual-core .question-box,
.result-core.ritual-core .ritual-figure-card{display:none !important}
.ritual-status{font-size:15px;line-height:1.7;color:var(--muted) !important;text-align:left !important}
.ritual-inline-figure{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.ritual-inline-figure .ritual-figure{max-width:120px}
.ritual-side-result .ritual-stage-wrap{grid-template-columns:1fr 160px !important;grid-template-areas:"stage formation" !important}
.ritual-side-result .ritual-history{display:none}
@media (max-width:1280px){
  .consult-grid{grid-template-columns:1fr !important}
  .ritual-side-panel{min-height:auto !important}
}
@media (max-width:760px){
  .ritual-stage-wrap,
  .ritual-side-result .ritual-stage-wrap{grid-template-columns:1fr !important;grid-template-areas:"stage" "formation" !important}
  .big-coin-row{gap:10px !important;min-height:150px !important}
  .coin-chip.large{width:86px !important;height:86px !important}
  .coin-chip .coin-value{font-size:9px !important}
}

/* --- 4.6 landing + primacía manual --- */
.landing-shell{
  max-width:1200px;
  margin:0 auto;
  padding:28px 22px 46px;
  display:grid;
  gap:18px;
}
.landing-hero{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);
  gap:24px;
  align-items:center;
  min-height:360px;
}
.landing-hero-copy h1{
  margin:8px 0 14px;
  font-size:64px;
  line-height:.98;
  letter-spacing:-.04em;
  font-weight:500;
  max-width:820px;
}
.landing-lead{
  margin:0;
  max-width:760px;
  color:var(--muted);
  line-height:1.9;
  font-size:19px;
}
.landing-cta-row{
  margin-top:24px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.closing-row{justify-content:flex-start}
.landing-art{
  position:relative;
  min-height:320px;
  display:grid;
  place-items:center;
}
.landing-mandala{
  width:min(320px,82vw);
  aspect-ratio:1;
  border-radius:50%;
  border:1px solid rgba(216,176,107,.14);
  background:
    radial-gradient(circle at center, rgba(216,176,107,.08), transparent 40%),
    repeating-radial-gradient(circle at center, rgba(216,176,107,.14) 0 2px, transparent 2px 20px);
  filter:drop-shadow(0 0 34px rgba(216,176,107,.12));
}
.landing-taiji{
  position:absolute;
  width:128px;
  height:128px;
}
.landing-feature-grid,.landing-steps-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.landing-feature,.landing-step-card{
  display:grid;
  gap:10px;
}
.landing-feature h2,.landing-step-card h2,.landing-method h2,.landing-potential h2{margin:0;font-size:32px;font-weight:500}
.landing-feature p,.landing-step-card p,.landing-method p{margin:0;color:var(--muted);line-height:1.8}
.primary-feature{
  border-color:rgba(216,176,107,.28);
  box-shadow:0 18px 48px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.02);
}
.landing-trust-grid,.landing-potential-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.landing-potential-grid{margin-top:18px}
.trust-note{
  margin:0 0 18px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(216,176,107,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  display:grid;
  gap:6px;
}
.trust-note strong{color:var(--gold-soft);font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.trust-note span{color:var(--muted);line-height:1.75}
.mode-caption{
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.7;
}
.mode-field .mode-label{margin-bottom:8px}

@media (max-width:960px){
  .landing-hero,.landing-feature-grid,.landing-steps-grid,.landing-trust-grid,.landing-potential-grid{grid-template-columns:1fr}
  .landing-hero-copy h1{font-size:50px}
}
@media (max-width:720px){
  .landing-shell{padding-left:14px;padding-right:14px}
  .landing-hero-copy h1{font-size:40px}
  .landing-lead{font-size:17px}
}

/* --- 5.1 identidad, privacidad y legal --- */
.check-field{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  line-height:1.6;
  font-size:14px;
}
.check-field input{
  margin-top:4px;
  accent-color:var(--gold);
}
.check-field a{color:var(--gold-soft)}
.auth-message{min-height:22px;color:var(--gold-soft);margin:12px 0}
.full{width:100%}
.legal-shell{display:grid;gap:18px}
.legal-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  padding:18px;
}
.legal-card h1,.legal-card h2{margin:0 0 12px;font-weight:500}
.legal-card p,.legal-card li{color:var(--muted);line-height:1.8}
.legal-list{margin:0;padding-left:20px;display:grid;gap:10px}
.narrow-shell{max-width:780px;margin:0 auto;padding:28px 22px 42px}
.btn.danger,.danger{
  border-color:rgba(220,118,118,.32);
  color:#ffd0d0;
  background:rgba(255,255,255,.02);
}
.danger-card{border-color:rgba(220,118,118,.18)}
.user-menu a,.user-menu button{display:block;width:100%;text-align:left;margin-top:8px}


/* --- 5.5 identidad TAO.AR --- */
.tao-hero-mark{
  margin-top:18px;
  color:var(--gold-soft);
  font-size:clamp(42px,8vw,86px);
  line-height:.92;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-shadow:0 0 34px rgba(216,176,107,.12);
}
.landing-subtitle{
  margin:-2px 0 16px;
  color:var(--gold);
  font-size:18px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.creator-line,
.brand-mini-credit{
  margin-top:14px;
  color:var(--gold-soft);
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.brand-mini-credit{margin-top:10px}
.project-footer{
  margin-top:22px;
  border:1px solid rgba(216,176,107,.14);
  border-radius:24px;
  padding:18px 20px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
  box-shadow:0 18px 48px rgba(0,0,0,.16);
}
.project-footer-brand{
  display:flex;
  gap:14px;
  align-items:center;
  min-width:0;
}
.project-footer-mark{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(216,176,107,.18);
  background:rgba(255,255,255,.03);
  color:var(--gold-soft);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  white-space:nowrap;
}
.project-footer-copy{
  display:grid;
  gap:4px;
}
.project-footer-copy strong{
  font-size:18px;
  font-weight:500;
}
.project-footer-copy span,
.project-footer-meta{
  color:var(--muted);
}
.project-footer-meta{
  display:grid;
  gap:4px;
  text-align:right;
  font-size:14px;
}
.project-footer-meta span:first-child{color:var(--gold-soft)}
.brand-note strong{color:var(--gold-soft)}
.tao-credit-card .meta-grid{margin-top:14px}

.pdf-viewer-shell{
  border:1px solid rgba(216,176,107,.16);
  border-radius:24px;
  padding:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
}
.pdf-viewer{
  width:100%;
  min-height:78vh;
  border:0;
  border-radius:18px;
  background:rgba(0,0,0,.28);
}

.admin-layout{display:grid;gap:18px}
.admin-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}
.admin-stat-card{min-height:136px}
.admin-stat-card h2{margin:8px 0 6px;font-size:42px;font-weight:500}
.admin-wide-card{grid-column:span 3}
.admin-health-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.admin-health-card,
.admin-audit-item,
.admin-summary-card{
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.03);
  padding:16px;
}
.admin-health-card h3,
.admin-summary-card h3{margin:8px 0 6px;font-size:22px;font-weight:500}
.admin-inline-list{display:flex;flex-wrap:wrap;gap:8px}
.admin-chip,
.admin-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(216,176,107,.16);
  background:rgba(255,255,255,.03);
  color:var(--gold-soft);
  font-size:12px;
}
.admin-badge.ok{border-color:rgba(111,201,143,.22);color:#d8f2dc}
.admin-badge.warn{border-color:rgba(216,176,107,.24);color:var(--gold-soft)}
.admin-badge.error{border-color:rgba(220,118,118,.22);color:#ffd0d0}
.admin-bars{display:grid;gap:10px;margin-top:16px}
.admin-bar-row{display:grid;grid-template-columns:120px 1fr auto;gap:12px;align-items:center}
.admin-bar-row span,
.admin-bar-row strong{font-size:13px}
.admin-bar{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  overflow:hidden;
}
.admin-bar i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(242,214,160,.72), rgba(216,176,107,.94));
}
.admin-search-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.admin-search-row input{flex:1 1 280px}
.admin-table-wrap{overflow:auto}
.admin-table{
  width:100%;
  min-width:1180px;
  border-collapse:collapse;
}
.admin-table th,
.admin-table td{
  padding:14px 12px;
  border-bottom:1px solid rgba(216,176,107,.12);
  vertical-align:top;
  text-align:left;
}
.admin-table th{
  color:var(--gold-soft);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.admin-table td{color:var(--ink);line-height:1.6}
.admin-cell-note{display:block;color:var(--muted);font-size:13px;line-height:1.5}
.admin-audit-list{display:grid;gap:12px}
.admin-audit-item header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:10px;
}
.admin-audit-item p{margin:0 0 10px;line-height:1.7}
.admin-audit-item pre{
  margin:0;
  white-space:pre-wrap;
  word-break:break-word;
  font-family:Consolas, "Courier New", monospace;
  font-size:12px;
  line-height:1.6;
  color:var(--muted);
}
.admin-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.plan-shell{margin:18px 0 22px}
.usage-banner{
  display:flex;
  gap:18px;
  justify-content:space-between;
  align-items:flex-start;
  padding:18px 20px;
  border:1px solid rgba(216,176,107,.16);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(21,24,33,.88), rgba(12,14,19,.96));
}
.usage-banner-main{flex:1 1 560px}
.usage-banner-main h3{margin:6px 0 10px;font-size:24px;font-weight:500}
.usage-banner-main p{margin:0;color:var(--muted);line-height:1.7}
.usage-banner-side{
  flex:0 0 280px;
  display:grid;
  gap:12px;
  justify-items:stretch;
}
.usage-cta-row{
  display:grid;
  gap:10px;
}
.usage-price{
  color:var(--gold-soft);
  font-size:15px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.usage-reset-note{color:var(--muted);font-size:13px;line-height:1.6}
.usage-list{display:grid;gap:8px;margin-top:14px;color:var(--muted);line-height:1.7}
.usage-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
.usage-metric{
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(216,176,107,.14);
  background:rgba(255,255,255,.025);
}
.usage-metric strong{display:block;color:var(--ink);margin-bottom:6px}
.usage-metric span,.usage-metric small{display:block;color:var(--muted);line-height:1.6}
.usage-metric.is-blocked{
  border-color:rgba(206,120,88,.38);
  box-shadow:inset 0 0 0 1px rgba(206,120,88,.16);
}
.usage-plan-stack{display:grid;gap:10px}
.plan-mini-card{
  display:grid;
  gap:4px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(216,176,107,.14);
  background:rgba(255,255,255,.03);
}
.plan-mini-card strong{color:var(--ink)}
.plan-mini-card span,.plan-mini-card small{color:var(--muted);line-height:1.5}
.plans-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.plan-column{
  border:1px solid var(--line);
  border-radius:26px;
  padding:20px 18px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  display:grid;
  gap:14px;
}
.plan-column.is-featured{
  border-color:rgba(216,176,107,.32);
  box-shadow:0 20px 50px rgba(0,0,0,.18);
}
.plan-column-header{
  display:grid;
  gap:6px;
}
.plan-column h2{
  margin:0;
  font-size:30px;
  font-weight:500;
}
.plan-price-note{
  color:var(--gold-soft);
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.plan-column p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
}
.plan-limit-list{
  display:grid;
  gap:10px;
}
.plan-limit-list div{
  border:1px solid rgba(216,176,107,.12);
  border-radius:18px;
  padding:12px 14px;
  background:rgba(255,255,255,.025);
}
.plan-limit-list strong{
  display:block;
  color:var(--gold);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.plan-foot-note{
  color:var(--muted);
  line-height:1.7;
  font-size:14px;
}
.btn.is-locked,
.mode-btn.is-locked,
textarea.is-locked,
input.is-locked{
  opacity:.54;
  cursor:not-allowed;
}
.admin-action-stack{display:grid;gap:10px}
.admin-plan-control{display:grid;gap:6px}
.admin-plan-control select{min-width:190px}
.admin-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 14px;
}
.admin-form-span-2{grid-column:span 2}
.admin-inline-check{
  align-self:end;
  min-height:54px;
}
#admin-user-detail{margin-bottom:16px}
.admin-detail-card{display:grid;gap:16px}
.admin-detail-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.admin-detail-block,
.admin-detail-panel{
  border:1px solid rgba(216,176,107,.12);
  border-radius:18px;
  background:rgba(255,255,255,.02);
  padding:14px;
  display:grid;
  gap:6px;
}
.admin-detail-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:end;
}
.admin-detail-columns{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.admin-benefit-row{
  border-top:1px solid rgba(216,176,107,.1);
  padding-top:10px;
  margin-top:10px;
  display:grid;
  gap:4px;
}
.admin-benefit-row:first-child{
  border-top:none;
  padding-top:0;
  margin-top:0;
}
.admin-benefit-row span,
.admin-benefit-row small{color:var(--muted);line-height:1.5}
@media (max-width:960px){
  .plans-grid{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion: reduce){
  body{
    background-attachment:scroll;
  }
  body.landing-intro-pending.landing-intro-active{
    overflow-x:hidden;
  }
  body.landing-intro-pending.landing-intro-active .landing-shell > *{
    opacity:1;
    transform:none;
    filter:none;
  }
  body.landing-intro-active.landing-intro-ready .landing-shell > *{
    transition:none;
  }
  .landing-intro-veil{
    display:none;
  }
}
@media (max-width:720px){
  .project-footer{
    flex-direction:column;
    align-items:flex-start;
  }
  .project-footer-meta{
    text-align:left;
  }
  .pdf-viewer{min-height:62vh}
  .usage-banner{flex-direction:column}
  .usage-banner-side{flex:1 1 auto;width:100%}
  .usage-metrics{grid-template-columns:1fr}
  .plans-grid{grid-template-columns:1fr}
  .auth-step-head{flex-direction:column;align-items:flex-start}
  .auth-inline-link-row{justify-content:flex-start}
  .admin-summary-grid,
  .admin-grid,
  .admin-health-grid,
  .admin-detail-grid,
  .admin-detail-columns,
  .admin-form-grid{grid-template-columns:1fr}
  .admin-wide-card{grid-column:auto}
  .admin-form-span-2{grid-column:auto}
  .admin-bar-row{grid-template-columns:1fr}
}
