/* Google Font */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600&display=swap');

:root{
  --accent:#b23cff;
  --bg:#fafafa;
  --card:#ffffff;
  --muted:#666;
  --max-width:1100px;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family: 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; background:var(--bg);color:#222}
img{max-width:100%;height:auto;display:block}
/* skip link for accessibility */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:8px 12px;background:#fff;border:2px solid var(--accent);border-radius:6px;left:18px;margin-top:8px}
.container{max-width:var(--max-width);margin:0 auto;padding:16px}

/* Header */
.header-grid{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:12px 0}
.logo a{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.site-meta{display:flex;flex-direction:column;text-align:right;font-size:14px}
.site-meta a{color:var(--accent);text-decoration:none}

nav{margin-top:8px}
.nav-list{display:flex;gap:12px;list-style:none;padding:0;margin:0}
.nav-list a{padding:8px 10px;border-radius:6px;text-decoration:none;color:#333;transition:all .2s ease}
.nav-list a:hover,.nav-list a:focus{background:var(--accent);color:#fff;outline:none}

/* Hero */
.hero{background:linear-gradient(180deg, #fff 0%, #fbf7ff 100%);border-radius:10px;padding:24px;margin:18px 0;display:grid;grid-template-columns:1fr;gap:16px;align-items:center}
.hero h1{font-size:28px;margin:0}
.hero p{margin:0;color:var(--muted)}
.hero .cta{display:inline-block;background:var(--accent);color:#fff;padding:10px 14px;border-radius:8px;text-decoration:none;transition:transform .15s, box-shadow .15s}
.hero .cta:hover{transform:translateY(-3px);box-shadow:0 8px 18px rgba(178,60,255,0.12)}

/* Grid of boxes (types) */
.types-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.type-card{background:var(--card);padding:12px;border-radius:8px;box-shadow:0 1px 0 rgba(0,0,0,0.04);transition:transform .18s ease}
.type-card:hover{transform:translateY(-6px)}
.type-card h3{margin:0 0 8px}

/* Footer */
footer{border-top:1px solid #e9e9e9;margin-top:24px;padding:18px 0;color:var(--muted)}
.footer-inner{display:grid;grid-template-columns:1fr auto;align-items:center}

/* Contact form */
form{display:grid;gap:10px;max-width:500px;background:var(--card);padding:12px;border-radius:8px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
label{font-size:14px}
label.required::after{content:' *';color:#c0392b;margin-left:3px}
input[type='text'],input[type='email'],textarea,select{padding:8px;border:1px solid #ddd;border-radius:6px}
input:required,textarea[aria-required='true']{box-shadow:0 0 0 3px rgba(178,60,255,0.06) inset}
button{background:var(--accent);color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer}
button:hover{opacity:.95}

/* Roller result */
.result{font-size:48px;font-weight:600;color:var(--accent);transition:transform .2s ease}
.roll-history{margin-top:8px;font-size:14px;color:var(--muted)}

/* Small devices (<=640) — mobile first is default */
@media(min-width:641px){
  .hero{grid-template-columns:1fr 320px}
  .types-grid{grid-template-columns:repeat(3,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}

/* Focus styles for accessibility */
a:focus, button:focus, input:focus, select:focus, textarea:focus{outline:3px solid rgba(178,60,255,0.14);outline-offset:2px}

/* Small utilities */
.kv{font-size:14px;color:var(--muted)}
.social{display:flex;gap:8px}
.logo-small{display:flex;align-items:center;gap:8px}

/* ensure required fields visually different */
input:required{border-color:#c0392b}

/* Ensure map is responsive */
.responsive-iframe{position:relative;padding-bottom:56.25%;height:0;overflow:hidden}
.responsive-iframe iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
