:root{
  --bg:#0d1010;
  --bg-top:#172020;
  --surface:#171a19;
  --surface-2:#1d221f;
  --surface-3:#242a27;
  --surface-soft:rgba(255,255,255,.03);
  --text:#f1ead8;
  --muted:#c5b89a;
  --line:rgba(213,188,131,.14);
  --line-strong:rgba(213,188,131,.28);
  --gold:#cfad6d;
  --gold-soft:#ebd199;
  --ember:#a4523c;
  --forest:#566d5c;
  --shadow:0 28px 80px rgba(0,0,0,.42);
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}

body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:"Cormorant Garamond", Georgia, serif;
  background:
    radial-gradient(circle at 18% 16%, rgba(164,82,60,.16), transparent 22%),
    radial-gradient(circle at 82% 12%, rgba(86,109,92,.18), transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(207,173,109,.08), transparent 30%),
    linear-gradient(180deg, #18201f, #0f1213 36%, #090a0b);
  overflow-x:hidden;
  position:relative;
}

body::before,
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
}

body::before{
  z-index:-2;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,245,220,.06), transparent 28%),
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.22));
}

body::after{
  z-index:-1;
  opacity:.26;
  background-image:
    radial-gradient(circle at 50% 100%, rgba(255,255,255,.035) 0 18px, transparent 19px),
    radial-gradient(circle at 0 0, transparent 0 66px, rgba(255,255,255,.016) 67px 72px, transparent 73px);
  background-size:56px 34px, 180px 180px;
  mask-image:linear-gradient(180deg, transparent, black 14%, black 86%, transparent);
}

#app{
  max-width:1440px;
  margin:0 auto;
  padding:36px 28px 60px;
}

.hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);
  gap:34px;
  align-items:center;
  margin-bottom:24px;
  padding:38px;
  border:1px solid var(--line-strong);
  border-radius:34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 22%),
    linear-gradient(130deg, rgba(86,109,92,.14), transparent 34%),
    radial-gradient(circle at 84% 16%, rgba(164,82,60,.18), transparent 24%),
    linear-gradient(180deg, rgba(29,34,31,.98), rgba(15,18,19,.98));
  box-shadow:var(--shadow);
  overflow:hidden;
  isolation:isolate;
}

.hero::before{
  content:"";
  position:absolute;
  inset:12px;
  border:1px solid rgba(255,245,220,.08);
  border-radius:24px;
  pointer-events:none;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent 45%, rgba(0,0,0,.14) 72%, rgba(0,0,0,.3)),
    radial-gradient(circle at 70% 30%, rgba(235,209,153,.06), transparent 26%);
  pointer-events:none;
}

.hero-copy,
.hero-side{
  position:relative;
  z-index:1;
}

.eyebrow{
  margin:0 0 12px;
  color:var(--gold-soft);
  font-family:"Cinzel", Georgia, serif;
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.hero h1,
.panel h2,
.panel h3,
.panel h4,
button,
.tab,
.stat .value,
.badge,
.total{
  font-family:"Cinzel", Georgia, serif;
}

.hero h1{
  margin:0;
  font-size:clamp(2.7rem, 6vw, 5.1rem);
  line-height:.95;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:#f7efd8;
  text-wrap:balance;
  text-shadow:0 0 30px rgba(235,209,153,.10);
}

.subtitle{
  max-width:760px;
  margin:16px 0 0;
  color:var(--muted);
  font-size:1.34rem;
  line-height:1.34;
}

.hero-meta,
.hero-actions,
.action-row,
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.hero-meta{
  margin-top:22px;
}

.hero-meta span{
  padding:10px 14px;
  border:1px solid rgba(213,188,131,.18);
  border-radius:999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02)),
    rgba(10,11,12,.22);
  color:#e9dcba;
  font-size:1rem;
}

.hero-side{
  display:grid;
  gap:18px;
}

.hero-art{
  position:relative;
  min-height:320px;
  border:1px solid var(--line);
  border-radius:30px;
  background:
    radial-gradient(circle at 50% 46%, rgba(235,209,153,.10), transparent 18%),
    radial-gradient(circle at 72% 26%, rgba(164,82,60,.22), transparent 18%),
    linear-gradient(145deg, rgba(255,255,255,.04), transparent 38%),
    linear-gradient(180deg, #222725, #131616);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
}

.hero-art::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(255,245,220,.08);
  border-radius:22px;
}

.hero-art::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 420 320'%3E%3Cg fill='none' stroke='%23cfad6d' stroke-width='6' stroke-linecap='round' stroke-linejoin='round' opacity='.9'%3E%3Cpath d='M145 103c-25 13-47 36-61 67 22-10 42-11 59-4-19 14-32 34-38 58 19-10 36-12 50-7'/%3E%3Cpath d='M275 103c25 13 47 36 61 67-22-10-42-11-59-4 19 14 32 34 38 58-19-10-36-12-50-7'/%3E%3Cpath d='M210 90c-36 0-67 26-72 63-4 33 13 65 43 84'/%3E%3Cpath d='M210 90c36 0 67 26 72 63 4 33-13 65-43 84'/%3E%3Ccircle cx='210' cy='124' r='24'/%3E%3Cpath d='M210 149v54'/%3E%3Cpath d='M196 188l14 34 18-38'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:78%;
  opacity:.16;
}

.hero-halo{
  position:absolute;
  inset:22% 20%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(235,209,153,.24), rgba(235,209,153,.05) 34%, transparent 62%);
  filter:blur(6px);
}

.hero-crest{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
}

.crest-ring,
.crest-core{
  position:absolute;
  display:grid;
  place-items:center;
}

.crest-ring{
  width:166px;
  height:166px;
  border:1px solid rgba(255,245,220,.18);
  border-radius:26px;
  transform:rotate(45deg);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    radial-gradient(circle at center, rgba(207,173,109,.18), transparent 58%);
}

.crest-ring::before,
.crest-ring::after{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(255,245,220,.14);
  border-radius:18px;
}

.crest-ring::after{
  inset:42px;
  border-radius:14px;
}

.crest-core{
  width:96px;
  height:96px;
  border:1px solid rgba(255,245,220,.18);
  border-radius:24px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255,255,255,.24), transparent 22%),
    linear-gradient(180deg, rgba(235,209,153,.22), rgba(164,82,60,.2));
  color:#fff3d7;
  font-size:2.25rem;
  text-shadow:0 0 18px rgba(255,245,220,.16);
}

button{
  border:none;
  border-radius:16px;
  padding:.95rem 1.2rem;
  font-size:.92rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

button:hover{
  transform:translateY(-2px);
}

button.primary{
  color:#26190f;
  background:
    linear-gradient(180deg, #efd7a3, #c79e57 72%, #8f6a35);
  box-shadow:0 14px 32px rgba(143,106,53,.28);
}

button.secondary{
  color:#ecdebc;
  border:1px solid rgba(213,188,131,.22);
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01)),
    linear-gradient(180deg, #312f2a, #1b1d1c);
}

.tabs{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
  margin:20px 0 24px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,0)),
    rgba(15,17,18,.48);
  box-shadow:0 18px 34px rgba(0,0,0,.18);
}

.tab{
  position:relative;
  padding:1rem 1.05rem;
  color:var(--muted);
  border:1px solid transparent;
  border-radius:16px;
  background:transparent;
}

.tab.active{
  color:#fff2d2;
  border-color:rgba(213,188,131,.24);
  background:
    linear-gradient(180deg, rgba(235,209,153,.14), rgba(164,82,60,.10)),
    linear-gradient(180deg, #32322d, #1d1f1e);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 12px 24px rgba(0,0,0,.18);
}

.tab.active::after{
  content:"";
  position:absolute;
  left:18px;
  right:18px;
  bottom:8px;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, rgba(235,209,153,.2), rgba(235,209,153,.9), rgba(235,209,153,.2), transparent);
}

.tab-panel{display:none}
.tab-panel.active{display:block}

.grid{
  display:grid;
  gap:20px;
}

.two-one{
  grid-template-columns:1.42fr 1fr;
}

.panel{
  position:relative;
  padding:24px;
  border:1px solid var(--line);
  border-radius:28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.025), transparent 16%),
    linear-gradient(180deg, rgba(30,34,32,.96), rgba(18,20,21,.97));
  box-shadow:var(--shadow);
  overflow:hidden;
}

.panel::before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(255,245,220,.07);
  border-radius:20px;
  pointer-events:none;
}

.panel::after{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  top:0;
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(235,209,153,.18), rgba(235,209,153,.62), rgba(235,209,153,.18), transparent);
}

.panel h2{
  margin:0 0 18px;
  color:#f1e2bf;
  font-size:1.42rem;
  letter-spacing:.06em;
}

.panel h3{
  margin:0 0 12px;
  color:#e6d3a9;
  font-size:1.02rem;
  letter-spacing:.04em;
}

.panel h4{
  margin:0 0 10px;
  color:var(--gold-soft);
  font-size:.9rem;
  letter-spacing:.06em;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(210px,1fr));
  gap:14px;
}

label{
  display:flex;
  flex-direction:column;
  gap:8px;
  color:var(--muted);
  font-size:1.04rem;
}

label > span{
  letter-spacing:.03em;
}

label.inline{
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.02);
}

input,
select,
textarea{
  width:100%;
  border:1px solid rgba(213,188,131,.18);
  border-radius:16px;
  padding:.88rem .95rem;
  color:var(--text);
  font:inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01)),
    linear-gradient(180deg, #2b2e2b, #181a1a);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}

input,
select,
textarea{
  font-size:16px;
}

input:focus,
select:focus,
textarea:focus,
button:focus{
  outline:none;
  border-color:rgba(235,209,153,.52);
  box-shadow:0 0 0 3px rgba(207,173,109,.16);
}

.builder-section{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(213,188,131,.10);
}

.status-groups{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
}

.chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.chip{
  min-width:170px;
  border:1px solid rgba(213,188,131,.12);
  border-radius:18px;
  padding:.9rem .95rem;
  color:#efe2c0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 34%),
    linear-gradient(180deg, #303330, #1b1d1d);
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.chip:hover{
  transform:translateY(-1px);
  border-color:rgba(213,188,131,.24);
}

.chip.active{
  border-color:rgba(235,209,153,.34);
  background:
    linear-gradient(180deg, rgba(235,209,153,.15), rgba(164,82,60,.08)),
    linear-gradient(180deg, #3a3b35, #222424);
  box-shadow:0 12px 24px rgba(0,0,0,.14);
}

.chip .mini{
  display:block;
  margin-top:6px;
  color:#cdbd9c;
  font-size:.92rem;
  line-height:1.25;
}

.chip input{
  margin-top:12px;
}

.card-stack{
  display:grid;
  gap:14px;
}

.card{
  position:relative;
  padding:18px;
  border:1px solid rgba(213,188,131,.10);
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 28%),
    linear-gradient(180deg, #2a2d2a, #171919);
}

.card::before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(255,245,220,.05);
  border-radius:14px;
  pointer-events:none;
}

.card h3{
  margin:.1rem 0 .5rem;
}

.muted{
  color:var(--muted);
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
}

.stat{
  padding:14px;
  border:1px solid rgba(213,188,131,.10);
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(235,209,153,.06), transparent 28%),
    linear-gradient(180deg, #303330, #1b1d1d);
}

.stat .label{
  color:var(--gold-soft);
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.stat .value{
  margin-top:6px;
  font-size:1.35rem;
  color:#fff3d2;
}

.list{
  margin:0;
  padding-left:20px;
  color:var(--muted);
}

.list li + li{
  margin-top:6px;
}

.badge-row{
  margin-top:10px;
}

.badge{
  padding:.45rem .82rem;
  border:1px solid rgba(213,188,131,.16);
  border-radius:999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    linear-gradient(180deg, #343632, #202221);
  color:#f1e5c5;
  font-size:.76rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.cost-table{
  width:100%;
  border-collapse:collapse;
}

.cost-table td,
.cost-table th{
  padding:9px 10px;
  text-align:left;
  border-bottom:1px solid rgba(213,188,131,.08);
}

.cost-table th{
  color:var(--gold-soft);
  font-weight:600;
}

.total{
  margin:.95rem 0 0;
  color:var(--gold-soft);
  font-size:1.14rem;
}

.saved-item{
  display:flex;
  justify-content:space-between;
  align-items:start;
  gap:14px;
  margin-bottom:10px;
  padding:14px;
  border:1px solid rgba(213,188,131,.10);
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 30%),
    linear-gradient(180deg, #2b2d2b, #181a1a);
}

.saved-item pre{
  margin:10px 0 0;
  white-space:pre-wrap;
  font-size:.92rem;
  color:#d5c5a6;
}

.saved-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:112px;
}

.note{
  color:#c4b390;
  font-size:.95rem;
}

.export-row{
  margin-top:16px;
}

.toast{
  position:fixed;
  right:20px;
  bottom:20px;
  max-width:360px;
  padding:14px 16px;
  border:1px solid rgba(213,188,131,.22);
  border-radius:18px;
  color:#fff3d2;
  background:
    linear-gradient(180deg, rgba(235,209,153,.16), rgba(164,82,60,.10)),
    linear-gradient(180deg, #34312b, #1d1e1e);
  box-shadow:0 22px 44px rgba(0,0,0,.34);
  opacity:0;
  transform:translateY(14px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:50;
}

.toast.show{
  opacity:1;
  transform:translateY(0);
}

@keyframes crestFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

.hero-crest{
  animation:crestFloat 7s ease-in-out infinite;
}

@media (max-width:1100px){
  .hero{
    grid-template-columns:1fr;
  }

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

  .two-one{
    grid-template-columns:1fr;
  }

  .status-groups{
    grid-template-columns:1fr;
  }
}

@media (max-width:720px){
  #app{
    padding:20px 16px 42px;
  }

  .hero{
    padding:24px 18px;
    gap:22px;
  }

  .hero-meta{
    gap:10px;
  }

  .hero-meta span{
    flex:1 1 100%;
    text-align:center;
  }

  .hero h1{
    font-size:clamp(2.2rem, 12vw, 3.5rem);
  }

  .subtitle{
    font-size:1.15rem;
  }

  .tabs{
    grid-template-columns:1fr;
    padding:8px;
  }

  .tab{
    padding:.95rem 1rem;
  }

  .cost-table{
    display:block;
    overflow-x:auto;
    white-space:nowrap;
  }

  .form-grid,
  .chip-grid{
    grid-template-columns:1fr;
  }

  .chip-grid{
    display:grid;
  }

  .chip{
    min-width:0;
    width:100%;
  }

  .hero-art{
    min-height:240px;
  }

  .crest-ring{
    width:138px;
    height:138px;
  }

  .crest-core{
    width:84px;
    height:84px;
    font-size:2rem;
  }

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

  label.inline{
    flex-direction:column;
    align-items:stretch;
  }

  .hero-actions,
  .action-row{
    flex-direction:column;
  }

  .hero-actions button,
  .action-row button,
  .saved-actions button{
    width:100%;
  }

  .saved-item{
    flex-direction:column;
  }

  .saved-actions{
    flex-direction:column;
    min-width:0;
    width:100%;
  }
}

@media (max-width:520px){
  #app{
    padding:16px 12px 32px;
  }

  .hero,
  .panel{
    padding:18px 14px;
  }

  .subtitle{
    font-size:1.05rem;
  }

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

  .saved-item pre{
    font-size:.86rem;
  }
}
