
:root{
  --bg:#f6f0e6;
  --paper:#fbf7f1;
  --ink:#2a241f;
  --muted:#6a5b4e;
  --wood:#8b5a2b;
  --wood-dark:#5b3a22;
  --line:#ddcfbe;
  --card:#fffaf4;
  --shadow:0 12px 28px rgba(44, 28, 15, .10);
  --radius:18px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Georgia, "Times New Roman", serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.45), transparent 28%),
    linear-gradient(180deg, #faf6f0, var(--bg));
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(calc(100% - 32px), var(--max)); margin:0 auto}
.topbar{
  background:#2d2017;
  color:#f4e7d7;
  font-size:.95rem;
}
.topbar .container{
  display:flex; gap:16px; justify-content:space-between; align-items:center;
  padding:10px 0;
  flex-wrap:wrap;
}
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:rgba(251,247,241,.92);
  border-bottom:1px solid rgba(107,88,66,.12);
}
.nav-wrap{
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:14px 0;
}
.brand{display:flex; align-items:center; gap:14px; min-width:0}
.brand img{width:70px; height:70px; object-fit:contain; border-radius:12px; background:white; padding:6px; box-shadow:var(--shadow)}
.brand-text{min-width:0}
.brand-text strong{display:block; font-size:1.2rem; letter-spacing:.02em}
.brand-text span{display:block; color:var(--muted); font-size:.95rem}
.nav{
  display:flex; gap:22px; align-items:center; flex-wrap:wrap; justify-content:flex-end;
}
.nav a{font-weight:700; font-size:.98rem}
.nav a:hover{color:var(--wood)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px; padding:13px 22px; font-weight:700;
  transition:.2s ease; border:1px solid transparent;
}
.btn-primary{background:linear-gradient(180deg, #9a6633, var(--wood)); color:#fff; box-shadow:0 10px 24px rgba(91,58,34,.20)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{background:var(--wood); color:#fff; border-color:var(--wood-dark)}
.btn-secondary:hover{background:var(--wood-dark); border-color:var(--wood-dark)}
.hero{
  padding:44px 0 24px;
}
.hero-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center;
}
.hero-copy{
  background:rgba(255,251,245,.74);
  border:1px solid rgba(139,90,43,.12);
  border-radius:30px;
  padding:40px;
  box-shadow:var(--shadow);
}
.eyebrow{
  color:var(--wood);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.86rem;
  font-weight:700;
}
.hero h1{
  font-size:clamp(2.2rem, 4vw, 4.3rem);
  line-height:1.05;
  margin:10px 0 16px;
}
.hero p{
  font-size:1.12rem; color:var(--muted); max-width:58ch; margin:0 0 24px;
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px}
.service-tags{display:flex; gap:10px; flex-wrap:wrap}
.service-tags span{
  background:#fff; border:1px solid var(--line); padding:9px 14px;
  border-radius:999px; font-size:.94rem; box-shadow:var(--shadow)
}
.hero-photo{
  position:relative; border-radius:30px; overflow:hidden; box-shadow:var(--shadow);
  min-height:540px; background:#dfd0bf;
}
.hero-photo img{width:100%; height:100%; object-fit:cover}
.hero-badge{
  position:absolute; right:18px; bottom:18px; background:rgba(45,32,23,.88); color:#fff;
  padding:14px 16px; border-radius:18px; max-width:270px;
}
.hero-badge strong{display:block}
.section{
  padding:42px 0;
}
.section-title{display:flex; align-items:end; justify-content:space-between; gap:14px; margin-bottom:22px}
.section-title h2{
  font-size:clamp(1.8rem, 3vw, 2.7rem); margin:0;
}
.section-title p{margin:0; color:var(--muted); max-width:55ch}
.card-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:20px;
}
.card{
  background:var(--card); border:1px solid rgba(107,88,66,.10); border-radius:24px; overflow:hidden; box-shadow:var(--shadow);
}
.card-media{aspect-ratio: 1 / .82; overflow:hidden}
.card-media img{width:100%; height:100%; object-fit:cover; transition:transform .35s ease}
.card:hover .card-media img{transform:scale(1.03)}
.card-body{padding:18px}
.card-body h3{margin:0 0 8px; font-size:1.25rem}
.card-body p{margin:0 0 14px; color:var(--muted); font-size:.98rem}
.link-arrow{font-weight:700; color:var(--wood)}
.about{
  display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:center;
}
.panel{
  background:var(--paper); border:1px solid rgba(107,88,66,.10); border-radius:28px; padding:30px; box-shadow:var(--shadow)
}
.checklist{display:grid; gap:12px; margin-top:18px}
.checklist div{display:flex; gap:10px; align-items:flex-start}
.check{width:24px; height:24px; border-radius:50%; background:#efe1d2; color:var(--wood); display:inline-flex; align-items:center; justify-content:center; font-weight:700; flex:none}
.gallery-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:16px;
}
.gallery-grid figure{
  margin:0; background:#fff; border-radius:20px; overflow:hidden; box-shadow:var(--shadow); border:1px solid rgba(107,88,66,.1)
}
.gallery-grid img{width:100%;height:auto;display:block;object-fit:contain;}
.gallery-grid figcaption{padding:12px 14px; font-size:.95rem; color:var(--muted)}
.cta{
  padding:52px 0 70px;
}
.cta-box{
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), transparent 36%),
    linear-gradient(180deg, #6a4528, #4a2f1f);
  color:#fff; border-radius:28px; padding:38px; box-shadow:var(--shadow);
  display:grid; grid-template-columns:1.15fr .85fr; gap:24px; align-items:center;
}
.cta-box p{color:#f2dfcd}
.footer{
  background:#241910; color:#eadbc8; margin-top:40px; padding:34px 0 26px;
}
.footer-grid{
  display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:24px;
}
.footer small, .footer p, .footer a{color:#dbc8b3}
.footer h4{margin:0 0 10px; color:#fff}
.list{display:grid; gap:8px}
.hero-mini{
  border-radius:24px; overflow:hidden; box-shadow:var(--shadow); margin-top:16px;
}
.page-hero{
  padding:28px 0 10px;
}
.page-hero .panel{
  display:grid; grid-template-columns:1fr .9fr; gap:24px; align-items:center;
}
.page-hero h1{margin:.2rem 0 .8rem; font-size:clamp(2rem, 3vw, 3.4rem)}
.page-hero p{color:var(--muted)}
.product-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:22px}
.product{
  background:#fff; border:1px solid rgba(107,88,66,.1); border-radius:24px; overflow:hidden; box-shadow:var(--shadow)
}
.product img{width:100%; aspect-ratio:1 / .72; object-fit:cover}
.product .body{padding:18px 18px 22px}
.meta{display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 14px}
.meta span{font-size:.9rem; padding:7px 10px; border:1px solid var(--line); border-radius:999px; background:#fbf7f1}
.notice{
  background:#fff7ea; border:1px solid #ead3a8; color:#6b4b13;
  border-radius:18px; padding:16px 18px; margin-top:16px;
}
.contact-grid{display:grid; grid-template-columns:.95fr 1.05fr; gap:22px}
.form-card{
  background:#fff; border-radius:24px; box-shadow:var(--shadow); border:1px solid rgba(107,88,66,.1); padding:24px;
}
label{display:block; margin-bottom:6px; font-weight:700}
input, select, textarea{
  width:100%; padding:13px 14px; border-radius:14px; border:1px solid #d6c5b4; background:#fff; font:inherit;
}
textarea{min-height:140px; resize:vertical}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.form-stack{display:grid; gap:14px}
.note{font-size:.92rem; color:var(--muted)}
@media (max-width: 980px){
  .hero-grid,.about,.cta-box,.page-hero .panel,.contact-grid{grid-template-columns:1fr}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-photo{min-height:420px}
}
@media (max-width: 700px){
  .nav-wrap{flex-direction:column; align-items:flex-start}
  .nav{gap:14px}
  .card-grid,.gallery-grid,.product-grid,.form-row,.footer-grid{grid-template-columns:1fr}
  .hero-copy,.panel,.cta-box,.form-card{padding:22px}
  .hero{padding-top:24px}
  .brand img{width:58px;height:58px}
}


.video-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:22px}
.video-card{background:#fff; border:1px solid rgba(107,88,66,.1); border-radius:24px; overflow:hidden; box-shadow:var(--shadow)}
.video-card video,.video-card img{width:100%; aspect-ratio:16/10; object-fit:cover; background:#000}
.video-card .body{padding:16px 18px}
.small-gallery{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:18px}
.small-gallery figure{margin:0; background:#fff; border-radius:18px; overflow:hidden; box-shadow:var(--shadow); border:1px solid rgba(107,88,66,.1)}
.small-gallery img{width:100%; aspect-ratio:1 / 1; object-fit:cover}
.small-gallery figcaption{padding:10px 12px; font-size:.92rem; color:var(--muted)}
@media (max-width: 980px){
  .video-grid,.small-gallery{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 700px){
  .video-grid,.small-gallery{grid-template-columns:1fr}
}

.engraving-split{display:grid; grid-template-columns:1.05fr .95fr; gap:22px; align-items:start}
.engraving-right{display:grid; gap:22px}
.engraving-collage-panel{padding:24px}
.split-heading{margin:.2rem 0 .5rem; font-size:1.45rem}
.split-copy{margin:0 0 16px; color:var(--muted)}
.keychain-collage-single{background:#fff; border-radius:18px; overflow:hidden; border:1px solid rgba(107,88,66,.1); box-shadow:var(--shadow); padding:14px}
.keychain-collage-single img{display:block; width:100%; height:auto; border-radius:12px}
@media (max-width: 980px){
  .engraving-split{grid-template-columns:1fr}
}

/* Contact form with Formspree + drag and drop */
.contact-panel{max-width:980px;margin:0 auto}
.contact-form{display:grid;gap:20px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.contact-form label{display:block;margin-bottom:8px;font-weight:700;color:#3b2a1a}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line, #d8c7b5);border-radius:12px;
  background:#fff;color:#2e261e;font:inherit;
}
.contact-form textarea{resize:vertical;min-height:160px}
.upload-wrap{display:grid;gap:10px}
.dropzone{position:relative;border:2px dashed #c8b29a;background:#fbf7f2;border-radius:18px;padding:28px 20px;cursor:pointer;transition:all .2s ease}
.dropzone:hover,.dropzone.is-dragover{border-color:#8b5a2b;background:#f6eee5}
.dropzone input[type="file"]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.dropzone-inner{display:grid;gap:6px;justify-items:center;text-align:center}
.dropzone-inner strong{font-size:1.05rem;color:#3b2a1a}
.dropzone-inner span{color:#6b6258}
.dropzone-inner small{color:#7b7268;max-width:42rem}
.file-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.file-list li{background:#fff;border:1px solid var(--line, #d8c7b5);border-radius:10px;padding:10px 12px;color:#4b4035}
.form-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.form-note{margin-top:18px}
@media (max-width: 768px){.form-grid{grid-template-columns:1fr}}


