:root {
--color-background: #f3efe8;
--color-background-deep: #ebe5dc;
--color-surface: #ffffff;
--color-surface-soft: #f8f5f0;
--color-surface-muted: #f1ece5;

--color-border: #ddd5ca;
--color-border-strong: #cbbfb0;

--color-text: #1f2422;
--color-text-soft: #3f4744;
--color-text-muted: #737873;

--color-accent: #2b453e;
--color-accent-dark: #1f342f;
--color-accent-light: #3e5c53;
--color-accent-soft: #e6eeea;

--color-gold: #a78655;
--color-gold-light: #c1a574;
--color-gold-soft: #f1e9dc;

--color-success: #2f6b4f;
--color-warning: #8a5f22;
--color-error: #9b3a36;

--shadow-soft: 0 20px 50px rgba(29, 35, 32, 0.08);
--shadow-card: 0 10px 28px rgba(29, 35, 32, 0.06);
--shadow-hover: 0 16px 36px rgba(29, 35, 32, 0.1);

--radius-large: 20px;
--radius-medium: 14px;
--radius-small: 9px;

--max-width: 1180px;
--transition: 180ms ease;
}

* {
  box-sizing: border-box;
  }

html {
scroll-behavior: smooth;
}

body {
margin: 0;
min-height: 100vh;
color: var(--color-text);
background:
radial-gradient(
circle at top right,
rgba(167, 134, 85, 0.12),
transparent 30rem
),
linear-gradient(
180deg,
#faf8f4 0%,
var(--color-background) 52%,
var(--color-background-deep) 100%
);
font-family:
Inter,
ui-sans-serif,
system-ui,
-apple-system,
BlinkMacSystemFont,
"Segoe UI",
sans-serif;
line-height: 1.6;
}

button,
input,
select,
textarea {
font: inherit;
}

button {
cursor: pointer;
}

button:disabled {
cursor: not-allowed;
opacity: 0.62;
}

a {
color: inherit;
}

.site-header {
position: relative;
overflow: hidden;
padding: 60px 24px 54px;
color: #ffffff;
background:
linear-gradient(
135deg,
#1f342f 0%,
#2b453e 68%,
#3d5b52 100%
);
}

.site-header::before {
content: "";
position: absolute;
inset: 0;
background:
linear-gradient(
90deg,
rgba(255, 255, 255, 0.025),
transparent 35%
);
}

.site-header::after {
content: "";
position: absolute;
top: -145px;
right: -100px;
width: 360px;
height: 360px;
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 50%;
box-shadow:
0 0 0 48px rgba(255, 255, 255, 0.022),
0 0 0 96px rgba(255, 255, 255, 0.015);
}

.header-content {
position: relative;
z-index: 1;
width: min(100%, var(--max-width));
margin: 0 auto;
}

.brand {
display: flex;
align-items: center;
gap: 18px;
}

.brand-mark {
display: grid;
flex: 0 0 auto;
width: 60px;
height: 60px;
place-items: center;
border: 1px solid rgba(255, 255, 255, 0.34);
border-radius: 15px;
background:
linear-gradient(
145deg,
rgba(255, 255, 255, 0.12),
rgba(255, 255, 255, 0.04)
);
box-shadow:
inset 0 1px 0 rgba(255, 255, 255, 0.14),
0 10px 24px rgba(0, 0, 0, 0.12);
font-size: 0.9rem;
font-weight: 700;
letter-spacing: 0.14em;
backdrop-filter: blur(10px);
}

.eyebrow {
margin: 0 0 5px;
color: var(--color-gold);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.18em;
text-transform: uppercase;
}

.site-header .eyebrow {
color: #ddc49b;
}

h1,
h2,
h3,
p {
margin-top: 0;
}

h1 {
margin-bottom: 0;
font-family:
Georgia,
"Times New Roman",
serif;
font-size: clamp(2.1rem, 4vw, 3.75rem);
font-weight: 500;
line-height: 1.08;
letter-spacing: -0.04em;
}

h2 {
margin-bottom: 0;
font-family:
Georgia,
"Times New Roman",
serif;
font-size: clamp(1.6rem, 2.5vw, 2.2rem);
font-weight: 500;
line-height: 1.2;
letter-spacing: -0.025em;
}

h3 {
margin-bottom: 0;
font-size: 1rem;
font-weight: 700;
letter-spacing: -0.01em;
}

.header-description {
max-width: 760px;
margin: 24px 0 0;
color: rgba(255, 255, 255, 0.76);
font-size: 1.05rem;
}

.page-shell {
display: grid;
width: min(calc(100% - 32px), var(--max-width));
margin: -20px auto 60px;
gap: 28px;
}

.panel {
border: 1px solid rgba(221, 213, 202, 0.9);
border-radius: var(--radius-large);
background: rgba(255, 255, 255, 0.965);
box-shadow: var(--shadow-soft);
backdrop-filter: blur(12px);
}

.form-panel,
.results-panel,
.records-panel {
padding: clamp(26px, 4vw, 44px);
}

.section-heading {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 20px;
margin-bottom: 32px;
}

.status-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 32px;
padding: 6px 12px;
border: 1px solid #ccd9d4;
border-radius: 999px;
color: var(--color-accent-dark);
background: var(--color-accent-soft);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
white-space: nowrap;
}

.form-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 20px;
}

.form-field {
display: flex;
flex-direction: column;
gap: 8px;
}

.full-width {
margin-top: 22px;
}

label {
color: var(--color-text-soft);
font-size: 0.88rem;
font-weight: 700;
}

label span {
color: var(--color-error);
}

.label-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
}

#character-count {
color: var(--color-text-muted);
font-size: 0.76rem;
}

input,
select,
textarea {
width: 100%;
border: 1px solid var(--color-border);
border-radius: var(--radius-small);
color: var(--color-text);
background: #ffffff;
outline: none;
box-shadow: inset 0 1px 1px rgba(31, 36, 34, 0.02);
transition:
border-color var(--transition),
box-shadow var(--transition),
background-color var(--transition);
}

input,
select {
min-height: 50px;
padding: 0 15px;
}

textarea {
min-height: 230px;
padding: 15px;
line-height: 1.65;
resize: vertical;
}

input::placeholder,
textarea::placeholder {
color: #9a9d99;
}

input:hover,
select:hover,
textarea:hover {
border-color: var(--color-border-strong);
}

input:focus,
select:focus,
textarea:focus {
border-color: var(--color-accent);
box-shadow:
0 0 0 4px rgba(43, 69, 62, 0.11),
inset 0 1px 1px rgba(31, 36, 34, 0.02);
}

.field-help {
margin: 0;
color: var(--color-text-muted);
font-size: 0.8rem;
}

.form-actions {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin-top: 28px;
}

.primary-button,
.secondary-button,
.copy-button,
.record-action {
border-radius: var(--radius-small);
font-weight: 700;
transition:
transform var(--transition),
box-shadow var(--transition),
background-color var(--transition),
border-color var(--transition);
}

.primary-button {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 220px;
min-height: 50px;
gap: 10px;
padding: 0 22px;
border: 1px solid transparent;
color: #ffffff;
background:
linear-gradient(
135deg,
var(--color-accent),
var(--color-accent-light)
);
box-shadow:
0 10px 22px rgba(43, 69, 62, 0.2),
inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.primary-button:hover:not(:disabled) {
background:
linear-gradient(
135deg,
var(--color-accent-dark),
var(--color-accent)
);
transform: translateY(-1px);
box-shadow:
0 14px 28px rgba(43, 69, 62, 0.26),
inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.secondary-button {
min-height: 44px;
padding: 0 18px;
border: 1px solid var(--color-border);
color: var(--color-text);
background: #ffffff;
}

.secondary-button:hover:not(:disabled) {
border-color: var(--color-border-strong);
background: var(--color-surface-soft);
transform: translateY(-1px);
}

.copy-button {
padding: 7px 11px;
border: 1px solid #d6e0dc;
color: var(--color-accent-dark);
background: var(--color-accent-soft);
font-size: 0.74rem;
}

.copy-button:hover {
background: #dbe8e2;
}

.button-spinner {
display: none;
width: 17px;
height: 17px;
border: 2px solid rgba(255, 255, 255, 0.38);
border-top-color: #ffffff;
border-radius: 50%;
animation: spin 700ms linear infinite;
}

.primary-button.is-loading .button-spinner {
display: inline-block;
}

@keyframes spin {
to {
transform: rotate(360deg);
}
}

.form-message {
min-height: 24px;
margin-top: 16px;
font-size: 0.88rem;
}

.form-message.success {
color: var(--color-success);
}

.form-message.error {
color: var(--color-error);
}

.form-message.info {
color: var(--color-accent);
}

.is-hidden {
display: none;
}

.result-summary-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 14px;
margin-bottom: 22px;
}

.summary-card {
min-height: 112px;
padding: 19px;
border: 1px solid var(--color-border);
border-radius: var(--radius-medium);
background:
linear-gradient(
180deg,
#fbfaf8,
var(--color-surface-soft)
);
}

.summary-label {
display: block;
margin-bottom: 8px;
color: var(--color-text-muted);
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
}

.summary-card strong {
display: block;
color: var(--color-text);
font-size: 0.95rem;
line-height: 1.45;
}

.result-content-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 18px;
}

.result-card {
min-width: 0;
padding: 23px;
border: 1px solid var(--color-border);
border-radius: var(--radius-medium);
background: #ffffff;
box-shadow: var(--shadow-card);
}

.result-card-wide {
grid-column: 1 / -1;
}

.result-card-heading {
display: flex;
align-items: center;
justify-content: space-between;
gap: 14px;
margin-bottom: 16px;
}

.result-card p {
margin-bottom: 0;
white-space: pre-wrap;
}

.result-card ol {
margin: 0;
padding-left: 22px;
}

.result-card li + li {
margin-top: 10px;
}

.tag-list {
display: flex;
flex-wrap: wrap;
gap: 8px;
}

.tag {
display: inline-flex;
align-items: center;
min-height: 30px;
padding: 5px 10px;
border: 1px solid #d7e1dd;
border-radius: 999px;
color: var(--color-accent-dark);
background: var(--color-accent-soft);
font-size: 0.76rem;
font-weight: 600;
}

#result-draft-message {
margin: 0;
overflow: auto;
color: var(--color-text);
background: transparent;
font-family: inherit;
font-size: 0.92rem;
line-height: 1.72;
white-space: pre-wrap;
}

.record-details {
margin-top: 22px;
border: 1px solid var(--color-border);
border-radius: var(--radius-medium);
background: var(--color-surface-soft);
}

.record-details summary {
padding: 15px 18px;
font-weight: 700;
cursor: pointer;
}

.record-details dl {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 14px;
margin: 0;
padding: 0 18px 18px;
}

.record-details dl div {
min-width: 0;
}

.record-details dt {
color: var(--color-text-muted);
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.09em;
text-transform: uppercase;
}

.record-details dd {
margin: 4px 0 0;
overflow-wrap: anywhere;
font-size: 0.86rem;
}

.records-list {
display: grid;
gap: 14px;
}

.records-message {
padding: 22px;
border: 1px dashed var(--color-border-strong);
border-radius: var(--radius-medium);
color: var(--color-text-muted);
background: var(--color-surface-soft);
text-align: center;
}

.record-item {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
align-items: center;
gap: 18px;
padding: 19px;
border: 1px solid var(--color-border);
border-radius: var(--radius-medium);
background: #ffffff;
transition:
transform var(--transition),
box-shadow var(--transition),
border-color var(--transition);
}

.record-item:hover {
border-color: #c8d5cf;
transform: translateY(-1px);
box-shadow: var(--shadow-hover);
}

.record-item h3 {
margin-bottom: 4px;
}

.record-meta {
display: flex;
flex-wrap: wrap;
gap: 8px 14px;
color: var(--color-text-muted);
font-size: 0.79rem;
}

.record-action {
min-height: 38px;
padding: 0 14px;
border: 1px solid var(--color-border);
color: var(--color-accent-dark);
background: var(--color-surface-soft);
}

.record-action:hover {
border-color: #c8d5cf;
background: var(--color-accent-soft);
}

.site-footer {
width: min(calc(100% - 32px), var(--max-width));
margin: 0 auto;
padding: 0 0 36px;
color: var(--color-text-muted);
font-size: 0.79rem;
text-align: center;
}

.site-footer p {
margin-bottom: 0;
}

::selection {
color: #ffffff;
background: var(--color-accent);
}

@media (max-width: 900px) {
.result-summary-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}

@media (max-width: 700px) {
.site-header {
padding: 44px 20px 42px;
}

.brand {
align-items: flex-start;
}

.brand-mark {
width: 50px;
height: 50px;
border-radius: 13px;
}

.page-shell {
width: min(calc(100% - 20px), var(--max-width));
margin-top: -12px;
}

.form-panel,
.results-panel,
.records-panel {
padding: 22px;
}

.section-heading {
flex-direction: column;
align-items: flex-start;
}

.form-grid,
.result-content-grid,
.record-details dl {
grid-template-columns: 1fr;
}

.result-card-wide {
grid-column: auto;
}

.record-item {
grid-template-columns: 1fr;
}
}

@media (max-width: 500px) {
h1 {
font-size: 2rem;
}

.result-summary-grid {
grid-template-columns: 1fr;
}

.form-actions {
flex-direction: column;
}

.primary-button,
.secondary-button {
width: 100%;
}

.label-row {
align-items: flex-start;
flex-direction: column;
gap: 4px;
}
}

@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
scroll-behavior: auto !important;
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
}
}
