/* ============================================================
   Ilm — shared design system
   Palette drawn from the app icon: deep teal ink + gold.
   Used across all pages (homepage layers its own section CSS).
   ============================================================ */
:root{
	--bg:#07140f;
	--bg-2:#0a1c16;
	--surface:#0d2019;
	--surface-2:#102a21;
	--gold:#d8b86a;
	--gold-2:#efd79a;
	--jade:#3f8571;
	--jade-dim:#1c4a3f;
	--text:#eef2eb;
	--text-2:#c4cdc6;
	--muted:#93a99e;
	--line:rgba(216,184,106,.15);
	--line-soft:rgba(255,255,255,.06);
	--shadow:0 30px 80px -30px rgba(0,0,0,.75);
	--ease:cubic-bezier(.22,1,.36,1);
	--maxw:1200px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
	margin:0;width:100%;
	background:var(--bg);
	color:var(--text);
	font-family:"Manrope",system-ui,sans-serif;
	font-size:17px;
	line-height:1.65;
	font-weight:400;
	-webkit-font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
	overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{
	font-family:"Fraunces",Georgia,serif;
	font-weight:400;
	line-height:1.05;
	letter-spacing:-.01em;
	margin:0;
}
::selection{background:var(--gold);color:#10221b}

/* ---------- Atmosphere ---------- */
.bg-layer{position:fixed;inset:0;z-index:-3;pointer-events:none}
.bg-base{
	background:
		radial-gradient(120% 90% at 78% -10%, rgba(63,133,113,.28), transparent 55%),
		radial-gradient(80% 70% at 12% 8%, rgba(216,184,106,.12), transparent 55%),
		radial-gradient(120% 120% at 50% 120%, rgba(28,74,63,.45), transparent 60%),
		linear-gradient(180deg,#07140f 0%,#06110d 100%);
}
.bg-pattern{z-index:-2;opacity:.5}
.bg-pattern svg{width:100%;height:100%}
.bg-grain{
	z-index:-1;opacity:.04;mix-blend-mode:overlay;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- Buttons ---------- */
.btn{
	display:inline-flex;align-items:center;justify-content:center;gap:.6em;
	font-family:inherit;font-weight:600;font-size:.95rem;letter-spacing:.01em;
	padding:.85em 1.5em;border-radius:100px;
	border:1px solid transparent;cursor:pointer;
	transition:transform .4s var(--ease),background .3s,border-color .3s,box-shadow .4s var(--ease);
}
.btn-gold{
	background:linear-gradient(180deg,var(--gold-2),var(--gold));
	color:#15271f;box-shadow:0 12px 30px -12px rgba(216,184,106,.6);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(216,184,106,.75)}
.btn-ghost{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-2);transform:translateY(-2px)}

/* Store badges */
.stores{display:flex;flex-wrap:wrap;gap:14px}
.store{
	display:inline-flex;align-items:center;gap:12px;
	padding:11px 20px 11px 18px;border-radius:14px;
	background:rgba(255,255,255,.035);
	border:1px solid var(--line-soft);
	transition:transform .4s var(--ease),border-color .3s,background .3s;
}
.store:hover{transform:translateY(-3px);border-color:var(--line);background:rgba(216,184,106,.07)}
.store svg{width:26px;height:26px;flex:none;fill:var(--text)}
.store .lbl{display:flex;flex-direction:column;line-height:1.15}
.store .lbl small{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.store .lbl span{font-size:1.05rem;font-weight:600;font-family:"Fraunces",serif}

/* ---------- Header ---------- */
header{
	position:fixed;top:0;left:0;right:0;z-index:50;
	transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s;
	border-bottom:1px solid transparent;
}
header.scrolled{
	background:rgba(7,17,13,.72);
	backdrop-filter:blur(16px) saturate(140%);
	-webkit-backdrop-filter:blur(16px) saturate(140%);
	border-bottom-color:var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;transition:height .4s var(--ease)}
header.scrolled .nav{height:66px}
.brand{display:flex;align-items:center;gap:12px;font-family:"Fraunces",serif;font-size:1.35rem;letter-spacing:.02em}
.brand img{width:38px;height:38px;border-radius:11px;box-shadow:0 6px 18px -6px rgba(0,0,0,.7)}
.brand b{font-weight:500}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a.lnk{
	font-size:.9rem;font-weight:500;color:var(--muted);position:relative;
	transition:color .3s;padding:4px 0;
}
.nav-links a.lnk::after{
	content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
	background:var(--gold);transition:width .35s var(--ease);
}
.nav-links a.lnk:hover{color:var(--text)}
.nav-links a.lnk:hover::after{width:100%}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;color:var(--text)}
.burger svg{width:26px;height:26px}

/* Mobile panel */
.mnav{
	position:fixed;inset:0 0 auto 0;z-index:49;
	background:rgba(7,17,13,.97);backdrop-filter:blur(20px);
	padding:96px 28px 36px;
	transform:translateY(-105%);transition:transform .5s var(--ease);
	border-bottom:1px solid var(--line);
}
.mnav.open{transform:translateY(0)}
.mnav a:not(.btn){display:block;font-family:"Fraunces",serif;font-size:1.7rem;padding:14px 0;border-bottom:1px solid var(--line-soft);color:var(--text)}
.mnav .btn{display:flex;width:100%}

/* ---------- Section frame ---------- */
section.block{position:relative;padding:96px 0}
.kicker{
	display:inline-block;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
	color:var(--gold);margin-bottom:18px;
}
.sec-head{max-width:620px;margin-bottom:56px}
.sec-head h2{font-size:clamp(2.1rem,4.2vw,3.2rem);font-weight:300}
.sec-head p{color:var(--muted);margin-top:18px;font-size:1.1rem}

/* ---------- Page hero (content pages) ---------- */
.page-hero{position:relative;padding:158px 0 30px}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.1rem);font-weight:300;letter-spacing:-.02em}
.page-hero h1 em{font-style:italic;color:var(--gold-2)}
.page-hero .meta{color:var(--muted);margin-top:16px;font-size:1.12rem;max-width:54ch}

/* ---------- Panel / prose (legal pages) ---------- */
.panel{
	background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008));
	border:1px solid var(--line-soft);border-radius:24px;
	padding:46px 54px;
}
.legal{max-width:880px;margin:0 auto}
.legal-updated{
	display:inline-block;font-size:.78rem;letter-spacing:.06em;color:var(--gold-2);
	border:1px solid var(--line);border-radius:100px;padding:6px 15px;margin-bottom:8px;
}
.legal h3{font-size:1.5rem;margin:42px 0 13px;color:var(--text)}
.legal h3:first-of-type{margin-top:8px}
.legal h4{font-family:"Manrope",sans-serif;font-size:1.02rem;font-weight:700;letter-spacing:.01em;margin:26px 0 8px;color:var(--gold-2)}
.legal p{color:var(--text-2);margin:0 0 16px}
.legal ul,.legal ol{color:var(--text-2);margin:0 0 20px;padding-left:24px;display:flex;flex-direction:column;gap:9px}
.legal li{padding-left:5px}
.legal li::marker{color:var(--gold)}
.legal strong{color:var(--text);font-weight:600}
.legal a{color:var(--gold-2);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line)}
.legal a:hover{text-decoration-color:var(--gold-2)}

/* ---------- Contact form ---------- */
.contact-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:40px;align-items:start}
.contact-aside h3{font-size:1.7rem;margin-bottom:14px}
.contact-aside p{color:var(--muted);margin:0 0 22px}
.contact-mail{
	display:inline-flex;align-items:center;gap:10px;color:var(--gold-2);font-weight:600;
	padding:12px 18px;border-radius:100px;border:1px solid var(--line);background:rgba(216,184,106,.06);
	transition:border-color .3s,background .3s,transform .3s var(--ease);
}
.contact-mail:hover{border-color:var(--gold);background:rgba(216,184,106,.12);transform:translateY(-2px)}
.contact-note{margin-top:26px;color:var(--muted);font-size:.86rem;display:flex;align-items:center;gap:9px}
.contact-note .dot{width:6px;height:6px;border-radius:50%;background:var(--jade);box-shadow:0 0 10px 1px var(--jade);flex:none}
.field{margin-bottom:20px}
.field label{display:block;font-size:.8rem;letter-spacing:.04em;color:var(--muted);margin-bottom:8px}
.field label small{color:var(--gold)}
.input{
	width:100%;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:13px;
	padding:14px 16px;color:var(--text);font-family:inherit;font-size:1rem;line-height:1.5;
	transition:border-color .3s,background .3s;
}
.input::placeholder{color:#5f6f67}
.input:focus{outline:none;border-color:var(--gold);background:rgba(0,0,0,.32)}
textarea.input{resize:vertical;min-height:150px}

/* ---------- Footer ---------- */
footer{margin-top:110px;border-top:1px solid var(--line-soft);padding:64px 0 40px;position:relative}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:48px}
.foot-brand{display:flex;align-items:center;gap:13px;font-family:"Fraunces",serif;font-size:1.5rem;margin-bottom:18px}
.foot-brand img{width:44px;height:44px;border-radius:12px}
.foot-col p{color:var(--muted);font-size:.95rem;max-width:34ch;margin:0}
.foot-col h5{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;font-weight:600;font-family:"Manrope",sans-serif}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.foot-col a{color:var(--muted);font-size:.95rem;transition:color .3s}
.foot-col a:hover{color:var(--gold-2)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:26px;border-top:1px solid var(--line-soft);color:var(--muted);font-size:.85rem;flex-wrap:wrap}
.foot-bottom .links{display:flex;gap:22px}
.foot-bottom a:hover{color:var(--gold-2)}

/* ---------- Back to top ---------- */
#toTop{
	position:fixed;right:26px;bottom:26px;width:46px;height:46px;border-radius:50%;z-index:40;
	display:grid;place-items:center;cursor:pointer;
	background:rgba(216,184,106,.12);border:1px solid var(--line);color:var(--gold-2);
	opacity:0;transform:translateY(14px);pointer-events:none;
	transition:opacity .4s,transform .4s var(--ease),background .3s;
}
#toTop.show{opacity:1;transform:translateY(0);pointer-events:auto}
#toTop:hover{background:rgba(216,184,106,.22)}
#toTop svg{width:20px;height:20px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
	.reveal{opacity:1;transform:none;transition:none}
	html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
	.foot-grid{grid-template-columns:1fr 1fr}
	.contact-grid{grid-template-columns:1fr;gap:30px}
}
@media (max-width:680px){
	body{font-size:16px}
	.nav-links{display:none}
	.burger{display:grid;place-items:center}
	.foot-grid{grid-template-columns:1fr;gap:34px}
	.foot-bottom{justify-content:center;text-align:center}
	.panel{padding:30px 22px}
	.page-hero{padding-top:130px}
}
